金砖

Problem

有一个长度为L的板凳,可以放一排金砖,金砖不能重叠。特别的,摆放的金砖可以超出板凳,前提是必须保证该金砖不会掉下去,即该金砖的重心必须在板凳上。

每块金砖都一个长度和价值,且金砖是规则的长方体。请计算最多可以摆放多少价值的金砖。

Input Data

第一行,两个整数N和L,分别表示金砖的数量和板凳的长度。

接下来N行,每行两个整数,ai和vi,分别表示第i块金砖的长度和价值。

Output Data

一行,一个整数,表示最大价值。

Input Sample 1

3 7
4 1
2 1
8 1

Output Sample 1

2

Input Sample 2

3 5
4 1
2 2
8 9

Output Sample 2

11

Input Sample 3

1 1
10 3

Output Sample 3

3

思路

要做这道题,得先掌握背包的一般思路,这里就不细讲了。

先说下思路。

At first,处理奇数长度的情况(没考虑清楚会WA一个点),因为对于奇数长度金砖,重心位置会出现小数的情况,这就让人很难堪。不过,可以把所有相关长度都乘2,或理解为以0.5为单位长度,这样就不用管奇数长度的情况了。

Secondly,咋处理能长出板凳的情况???直接按题目思路不好考虑,就把它转换一下吧。首先,我们很容易得知,最边上的两块要最靠边,及刚好不掉下去,这样可以腾出更大的空间给放在中间的金砖s。然后呢?有些人可能会想预处理出所有不超过板凳长度能放多少价值,再枚举两边的金砖,最后取最大值。However,重复取金砖的情况怎么考虑???其实我们可以当做最靠边的金砖长度打五折,或者说有两个金砖长度折半,具体实现就是把f数组再开一维记录已经取了几个“半价“金砖,最后取最大值即可。

Finally,还要考虑长度远大于L的金砖(更严谨地说,就是指长度 > 2 * L的金砖),它们即使“半价”处理也无法放上板凳,但是实际上可以把金砖的重心刚好放在板凳上,两边尽管长出去。好在这种情况会使金砖独占板凳,所以说直接用v来更新ans的值。

具体实现就在下面啦:

代码

#include<bits/stdc++.h>
using namespace std;
#define MAXN 4005
#define LL long long int N, L;
LL f[MAXN]; int main(){
scanf( "%d%d", &N, &L ); L *= 2;
LL ans(0);//注意开long long !important
for ( int i = 1; i <= N; ++i ){
LL a, v;
scanf( "%lld%lld", &a, &v );
a *= 2;
if ( a > L * 2 ) ans = max( ans, v );
else
for ( int j = L; j >= 1; --j ){//注意零一背包要倒过来
for ( int k = 0; k <= 2; ++k ){
if ( j >= a ) f[j][k] = max( f[j][k], f[j - a][k] + v );//放在中间
if ( k && j >= a / 2 ) f[j][k] = max( f[j][k], f[j - a / 2][k - 1] + v );//放在两边,既“半价处理”
ans = max( ans, f[j][k] );//更新ans的值
}
}
}
printf( "%lld", ans );
return 0;
}

撒花!(刚好下课)

「2015南阳CCPC D」金砖 解题报告的更多相关文章

  1. 2015南阳CCPC D - Pick The Sticks dp

    D - Pick The Sticks Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 无 Description The story happened lon ...

  2. 2015南阳CCPC E - Ba Gua Zhen 高斯消元 xor最大

    Ba Gua Zhen Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 无 Description During the Three-Kingdom perio ...

  3. 2015南阳CCPC F - The Battle of Guandu 多源多汇最短路

    The Battle of Guandu Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 无 Description In the year of 200, t ...

  4. 2015南阳CCPC L - Huatuo's Medicine 水题

    L - Huatuo's Medicine Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 无 Description Huatuo was a famous ...

  5. 2015南阳CCPC H - Sudoku 暴力

    H - Sudoku Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 无 Description Yi Sima was one of the best cou ...

  6. 2015南阳CCPC G - Ancient Go 暴力

    G - Ancient Go Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 无 Description Yu Zhou likes to play Go wi ...

  7. 2015南阳CCPC C - The Battle of Chibi DP

    C - The Battle of Chibi Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 无 Description Cao Cao made up a ...

  8. 2015南阳CCPC A - Secrete Master Plan 水题

    D. Duff in Beach Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 无 Description Master Mind KongMing gave ...

  9. 2015 南阳ccpc The Battle of Chibi (uestc 1217)

    题意:给定一个序列,找出长度为m的严格递增序列的个数. 思路:用dp[i][j]表示长度为i的序列以下标j结尾的总个数.三层for循环肯定超时,首先离散化,离散化之后就可以用树状数组来优化,快速查找下 ...

随机推荐

  1. OO第四单元博客作业

    OO第四单元博客作业 BUAA_1706_HugeGun 目录 第四单元作业架构设计 四个单元架构设计及OO方法理解 四个单元测试理解与实践演进 课程收获 一点建议 第四单元作业架构设计 ### 第十 ...

  2. Spark JDBC系列--Mysql tinyInt字段特殊处理

    当spark取出表的scheme中,类型名为tinyint的字段,会被处理为Boolean型.而mysql中tinyint的sqlType都会默认处理为bit,所以如果数据库中的这类字段中,存储了0. ...

  3. 2019南昌网络赛-I. Yukino With Subinterval 线段树套树状数组,CDQ分治

    TMD...这题卡内存卡的真优秀... 所以以后还是别用主席树的写法...不然怎么死的都不知道... 树套树中,主席树方法开权值线段树...会造成空间的浪费...这道题内存卡的很紧... 由于树套树已 ...

  4. 神经网络入门——7or 感知器

    OR 感知器 OR 感知器与 AND 感知器很类似,在下图中,OR 感知器与 AND 感知器有相同的分割线,只是 OR 感知器分割线下移了一段距离.对权重或者偏置做怎样的设置可以实现这个效果?用下面的 ...

  5. Activiti学习之spring boot 与activiti整合

    声明:本文是springboot2.0的多项目构建,springboot2.0和spingboot1.5的配置是有出入的,构建项目之前请规范您的springboot版本,选择2.0以上. 一.在IDE ...

  6. java分配内存空间

    分配内存空间 数组名=new 数据类型[数组长度]: new关键字用来实现为数组或对象分配内存 (堆内存) 数组具有固定的长度.获取数组的长度: 数组名.length 定义数组+分配内存空间 数据类型 ...

  7. html(四)数据库curd操作与分页查询

    数据库操作curd : 1.首先要建立项目处理好自己逻辑包: 其中util工具包中建立两个工具类 jdbc连接和page分页 DBUtil.java: db工具类就是用于连接数据库的jdbc架包,里面 ...

  8. Vue之webpack的entry和output

    一.文件结构 二.index.html <!DOCTYPE html> <html lang="en"> <head> <meta cha ...

  9. 再一次利用with as 优化SQL

    上海的一个哥们问我有个SQL跑了4个小时都没跑完,实在受不了了,找我优化一下.我确实挺佩服他的,要是我遇到跑了几分钟的,就受不了了. SQL语句和执行计划如下: --sql id:1qbbw3th4x ...

  10. web.xml和@WebServlet

    web.xml <servlet> <servlet-name>DZDYServlet</servlet-name> <servlet-class>包名 ...