hdu-2159(完全背包)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2159
思路:完全背包,但有次数的限制,因此,对次数进行dp,判断次数是否超限。
#include<iostream> #include<cstdio> #include<cstring> using namespace std; int n,m,k,s; int cost[120],vol[120],dp[120],num[120]; int main(void) { int i,j; while(cin>>n>>m>>k>>s) { for(i=0;i<k;i++) cin>>cost[i]>>vol[i]; memset(dp,0,sizeof(dp)); memset(num,0,sizeof(num)); for(i=0;i<k;i++) { for(j=vol[i];j<=m;j+=vol[i]) { if(dp[j]<dp[j-vol[i]]+cost[i]) { dp[j]=dp[j-vol[i]]+cost[i]; num[j]=max(num[j],num[j-vol[i]]+1); } } } int fg=0; for(i=0;i<=m;i++) if(dp[i]>=n) { fg=1;break; } if(fg&&num[i]<=s) cout<<m-i<<endl; else cout<<-1<<endl; } return 0; }