思路:

如果体积乘以数量>=W,那么直接用完全背包模型。如果不到的话,用二进制优化就好了。

基础题,感觉这样写很优雅?回去睡觉。

#include <bits/stdc++.h>
using namespace std;
typedef long long LL; int dp[50010],n,W;
int c,w,v; void zero_or_one(int val,int wi)
{
for(int i=W;i>=wi;i--)
dp[i]=max(dp[i],dp[i-wi]+val);
} void complete(int val,int wi)
{
for(int i=wi;i<=W;i++)
dp[i]=max(dp[i],dp[i-wi]+val);
} int main()
{
int k;
scanf("%d%d",&n,&W);
memset(dp,0,sizeof(dp));
for(int i=1;i<=n;i++)
{
scanf("%d%d%d",&w,&v,&c);
if(c*w>=W)
complete(v,w);
else
{
k=1;
while(k<c)
{
int ww=w*k;
int vv=v*k;
zero_or_one(vv,ww);
c-=k;
k<<=1;
}
k=c;
int ww=w*k;
int vv=v*k;
zero_or_one(vv,ww);
}
}
printf("%d\n",dp[W]);
return 0;
}

最新文章

  1. 2016最后一贴,终于调通一个测试示例,并发现一个BUG???
  2. IOS开发:监听来电状态的改变。
  3. Linux下安装DB2_v9.7详细教程
  4. IntelliJ IDEA 目录技巧
  5. EF结合三层:三层中数据层父类和业务层父类的使用
  6. 团队交流合作简单解决方案:TeamViewer远程控制&amp;会议演示 + HyperCam屏幕录制(免费)
  7. [hive小技巧]使用limit查询变成抽样,而不是全盘扫描
  8. 三星 PMU NXE2000,x-powers的AXP228,NXE2000
  9. RING0,RING1,RING2,RING3
  10. cocos2d中box2d讲解一
  11. 骁龙735处理器细节曝光:7nm工艺加持,支持5G
  12. 移动端开发H5页面点击按钮后出现闪烁或黑色背景的解决办法
  13. ssh 免登录
  14. Web jsp开发学习——新建一个项目
  15. Day1 Excel基本知识
  16. CodeDom生成类文件
  17. You don&#39;t have permission to access
  18. Docker应用系列(一)| 构建Redis哨兵集群
  19. registered the JDBC driver [com.mysql.jdbc.Driver] but failed to unregister it when the web application was stopped.
  20. xiaochengxubeijingt

热门文章

  1. 【题解】P3796【模板】AC自动机(加强版)
  2. Versions 崩溃(Mac升级OS X Yonsemite 10.10)
  3. COPY SAP 标准gui状态
  4. PAT 乙级 1085. PAT单位排行 (25) 【结构体排序】
  5. debian下编译openwrt固件
  6. 单页导航菜单视觉设计HTML模板
  7. Cocos2d-x中定时器的使用
  8. ICE 迁移64位安装问题
  9. arm-linux-gcc4.4.3编译s3c2410平台linux内核
  10. composer镜像安装laravel