首页 > 代码库 > HDU2191 悼念512汶川大地震遇难同胞——珍惜现在,感恩生活
HDU2191 悼念512汶川大地震遇难同胞——珍惜现在,感恩生活
标准的多重背包应用,只要 看了 背包九讲应该就会做了的题目;
用结构体做比较省事;
这题比较蛋疼的是 中间把 数量打成重量,找了半天也找不出来,又看了几遍PO3还是没找出来...抱着奇怪的心里,搜了一下.我去...
唉..以后要好好注意写代码的习惯了...
1 #include<iostream> 2 #define maxn 105 3 #define max(a,b) (a>b?a:b) 4 int dp[maxn]; 5 int n,m,t; 6 struct node 7 { 8 int amount,weight,price; 9 }game[maxn];10 void zeroOnePack(int cost,int weight)11 {12 for(int i=n;i>=cost;i--)13 dp[i]=max(dp[i],dp[i-cost]+weight);14 }15 void completePack(int cost ,int weight)16 {17 for(int i=cost;i<=n;i++)18 dp[i]=max(dp[i],dp[i-cost]+weight);19 }20 void multiPack(int cost,int weight,int amount)21 {22 23 if(cost * amount >= n)24 completePack(cost,weight);25 else26 {27 int k=1;28 while( k< amount)29 {30 zeroOnePack(k*cost,k*weight);31 amount-=k;32 k*=2;33 }34 zeroOnePack(amount*cost,amount*weight);35 }36 }37 38 int main()39 {40 //freopen("2191.txt","r",stdin);41 int i,j;42 while(~scanf("%d",&t))43 {44 while(t--)45 {46 memset(dp,0,sizeof(dp));47 memset(game,0,sizeof(game));48 scanf("%d %d" ,&n,&m);49 for(i=0;i<m;i++)50 scanf("%d %d %d",&game[i].price,&game[i].weight,&game[i].amount);51 for(i=0;i<m;i++)52 multiPack(game[i].price,game[i].weight,game[i].amount);53 printf("%d\n",dp[n]);54 }55 }56 return 0;57 }
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。