其实也算不上是裸的完全背包 因为需要保证恰好到那个重量 很幸运的是我一下子就想到了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;
}