题目
提示
完全背包问题
其实把01背包问题的代码改一下就可以了
详见我的 采药 那篇博客
O(∩_∩)O哈哈~
AC代码
//完全背包问题
#include<cstdio>
#include<iostream>
#include<algorithm>
#define N 10000005
using namespace std;
long long c[N],w[N],f[N];//c是空间,w是价值
int main()
{
int T,M;
cin>>T>>M;
for(int i=1;i<=M;i++){
cin>>c[i]>>w[i];
}
for(int i=1;i<=M;i++){//滚动数组,至于第一行有关,一维数组足够
for(int j=c[i];j<=T;j++){//保证取的不超过背包空间
f[j]=max(f[j],f[j-c[i]]+w[i]);//答案至于j有关
}
}
cout<<f[T];
return 0;
}
谢谢大家