HDOJ(HDU).2844 Coins (DP 多重背包+二进制优化)
来源:互联网 发布:2017年春运大数据 编辑:程序博客网 时间:2024/05/13 12:27
HDOJ(HDU).2844 Coins (DP 多重背包+二进制优化)
题意分析
先把每种硬币按照二进制拆分好,然后做01背包即可。需要注意的是本题只需要求解可以凑出几种金钱的价格,而不需要输出种数。因此用0表示不可以,1表示可以。最后对dp数组扫描一遍即可。
代码总览
#include <iostream>#include <cstdio>#include <cstring>#include <algorithm>#define nmax 100000#define nn 105#define INIT(x,y) memset(x,y,sizeof(x))using namespace std;int a[nn],c[nn];int pri[nmax],num[nmax],dp[nmax];int main(){ //freopen("in.txt","r",stdin); int n,m; while(scanf("%d%d",&n,&m) && n){ INIT(dp,0); INIT(a,0);INIT(c,0); INIT(pri,0);INIT(num,0); for(int i = 1; i<=n;++i) scanf("%d",&a[i]); for(int i = 1; i<=n;++i) scanf("%d",&c[i]); int cnt = 0; for(int k =1 ;k<=n ;++k){ for(int i =1; i<=c[k];i*=2){ pri[cnt] = i * a[k]; num[cnt++] = i * 1; c[k]-=i; } if(c[k]>0){ pri[cnt] = c[k] * a[k]; num[cnt++] = c[k]; } } dp[0] = 1; for(int i = 0; i<=cnt;++i){ for(int j = m; j>=pri[i]; --j){ //dp[j] = max(dp[j],dp[j-pri[i]]+1); if(dp[j-pri[i]]) dp[j] =1; }// for(int i =0;i<=m;++i) printf(" %3d",dp[i]);// printf("\n"); }// for(int i =1;i<=m;++i) printf(" %3d",i);// printf("\n");//// printf("%d\n"); int ans = 0; for(int i = 1;i<=m;++i) if(dp[i] == 1) ans++; printf("%d\n",ans); } return 0;}
0 0
- HDOJ(HDU).2844 Coins (DP 多重背包+二进制优化)
- hdu 2844 Coins(dp 多重背包 二进制优化)
- [HDU 2844 Coins]DP+二进制优化+多重背包
- hdu 2844 Coins(多重背包+二进制优化)
- hdu 2844 Coins 多重背包+二进制优化
- hdu 2844 coins (多重背包+二进制优化)
- hdu-2844-Coins (多重背包+二进制优化)
- HDU 2844 Coins(多重背包 + 二进制优化 + 01背包)
- hdu 2844 Coins(多重背包+二进制优化)
- HDU 2844 Coins (多重背包+二进制优化模板)
- HDU 2844 Coins (二进制优化多重背包)
- HDU 2844 Coins 多重背包(二进制优化)
- HDU 2844 Coins(多重背包【二进制优化】)
- HDU-2844-Coins(多重背包 二进制优化)
- hdu 2844 Coins(多重背包+二进制优化)
- HDOJ(HDU).1059 Dividing(DP 多重背包+二进制优化)
- hdoj 2844 Coins【多重背包】【dp】
- (DP,多重背包) Coins --HDOJ
- 1197
- 小巴学车有关项目的总结
- Thrift入门介绍
- 再探Java中的继承加载顺序
- mysql的历史命令记录,~/.mysql_history
- HDOJ(HDU).2844 Coins (DP 多重背包+二进制优化)
- 小米品牌广告引擎与算法实践
- 图片和文字完美结合
- 如何发布Web项目到互联网
- 康复计划#2 常用基础数论知识杂烩
- 4-安卓底层-HAL层-实现安卓控制LED
- Linux环境安装SVN
- Yii2 关于自带邮件的相关问题
- Android图片上传(头像裁切+原图原样)