标签:
转载请注明出处:http://blog.csdn.net/u012860063
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2191
1 8 2 2 100 4 4 100 2
400
多重背包转换为01背包问题:
代码例如以下:
#include <cstdio>
#include <cstring>
#define N 247
int max(int a,int b)
{
if(a > b)
return a;
else return b;
}
int main()
{
int t,n,m,i,j,k;
int w[N],pri[N],num[N],f[N];
while(~scanf("%d",&t))
{
while(t--)
{
memset(f,0,sizeof(f));
scanf("%d%d",&n,&m);//n为总金额,m为大米种类
for(i = 0 ; i < m ; i++)
{
scanf("%d%d%d",&pri[i],&w[i],&num[i]);//num[i]为每种大米的袋数
}
for(i = 0 ; i < m ; i++)
{
for(k = 0 ; k < num[i] ; k++)
{
for(j = n ; j >= pri[i]; j--)
{
f[j] = max(f[j],f[j-pri[i]]+w[i]);
}
}
}
printf("%d\n",f[n]);
}
}
return 0;
}
hdu2191 悼念512汶川大地震遇难同胞——珍惜如今,感恩生活
标签:
原文地址:http://www.cnblogs.com/mengfanrong/p/4256787.html