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