国产探花免费观看_亚洲丰满少妇自慰呻吟_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;}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 建始县| 夏河县| 莫力| 淮南市| 炎陵县| 德化县| 屏南县| 乌什县| 二连浩特市| 永丰县| 界首市| 铅山县| 宿州市| 阜康市| 永善县| 双柏县| 辉县市| 台州市| 沽源县| 瑞昌市| 探索| 乌鲁木齐市| 永春县| 翁牛特旗| 盐城市| 金川县| 灌南县| 蚌埠市| 宜都市| 康乐县| 河东区| 科尔| 崇信县| 湄潭县| 安化县| 西宁市| 涟水县| 龙游县| 安徽省| 阿拉善右旗| 贡山|