国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

HDOJ(HDU).2844 Coins (DP 多重背包+二進制優化)

2019-11-08 01:45:36
字體:
來源:轉載
供稿:網友

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;}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 玉树县| 太仓市| 肃北| 华坪县| 柘荣县| 手游| 湛江市| 郓城县| 麦盖提县| 奉新县| 留坝县| 抚宁县| 喀喇沁旗| 保德县| 云林县| 公主岭市| 东方市| 杭州市| 新平| 沅江市| 临邑县| 大新县| 乌拉特中旗| 宝山区| 阳江市| 米脂县| 谢通门县| 扶余县| 梓潼县| 湖南省| 时尚| 长沙市| 丰顺县| 皮山县| 南溪县| 永年县| 喀什市| 辛集市| 健康| 新昌县| 广水市|