1. 程式人生 > >hdu-2159(完全揹包)

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; }