标准完全背包板子,动态方程为dp[j][x]=max(dp[j][x],dp[j-c[i]][x-1]+a[i]); 其中,dp[j][x]表示花费j点耐心杀x个怪所能得到的最大经验值。
具体代码如下:
#include<iostream>
#include<string.h>
using namespace std;
int n,m,i,j,k,s;
int a[150],c[150],dp[105][105];
int ys=0;
int main()
{
while(scanf("%d%d%d%d",&n,&m,&k,&s)!=EOF)
{
if(n==0&&m==0) break;
ys=0;
for(i=0;i<k;i++) scanf("%d%d",&a[i],&c[i]);
for(i=0;i<=m;i++)
for(j=0;j<=s;j++) dp[i][j]=0;
int ans=0,flag=0;
for(i=0;i<k;i++)
for(j=c[i];j<=m;j++)
for(int x=1;x<=s;x++)
{
dp[j][x]=max(dp[j][x],dp[j-c[i]][x-1]+a[i]);
if(dp[j][x]>=n)
{
flag=1;
ans=max(ans,m-j);
}
}
if(!flag) cout<<"-1"<<endl;
else cout<<ans<<endl;
}
}