hdu1114Piggy-Bank【完全背包基础题】

其实也算不上是裸的完全背包 因为需要保证恰好到那个重量 很幸运的是我一下子就想到了dp[]数组的初始化方法得意

但是悲催的是自己数组开小了敲打

/********
hdu1114
2015.10.26
78MS 1612K 762 B
********/
#include <iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
using namespace std;
int p[505],w[505],dp[10005],e,f,t,n;
int main()
{
    //freopen("cin.txt","r",stdin);
    scanf("%d",&t);
    while(t--)
    {
        scanf("%d%d",&e,&f);
        scanf("%d",&n);
        for(int i=1;i<=n;i++) scanf("%d%d",&p[i],&w[i]);
        memset(dp,0x3f3f3f3f,sizeof(dp));
        dp[0]=0;
        for(int i=1;i<=n;i++)
            for(int j=w[i];j<=f-e;j++)
                dp[j]=min(dp[j],dp[j-w[i]]+p[i]);
        if(dp[f-e]<0x3f3f3f3f)
         printf("The minimum amount of money in the piggy-bank is %d.\n",dp[f-e]);
        else printf("This is impossible.\n");
    }
    return 0;
}


你可能感兴趣的:(算法,dp,HDU)