首先按照收获从大到小排序。

然后01背包取或者不取即可。

至于为什么这样对的其实我也不知道。。。。

代码:

#include<bits/stdc++.h>
using namespace std;
int T,n,f;
struct xx
{
    int d,r,val;
}num[100003];
inline bool cmp(xx a,xx b)
{
    if(a.r==b.r)return a.d>b.d;
    return a.r>b.r;
}
int jiyi[53][50003];
int dp(int now,int val)
{
    int &fanhui=jiyi[now][val];
    if(fanhui!=-1)return fanhui;
    if(now==n+1)return fanhui=0;
    fanhui=dp(now+1,val);
    if(val>=num[now].d)
     fanhui=max(dp(now+1,val-num[now].val)+1,fanhui);
    return fanhui;
}
int main()
{
    scanf("%d",&T);
    while(T--)
     {
        memset(jiyi,-1,sizeof(jiyi));
        scanf("%d%d",&n,&f);
        for(int i=1;i<=n;i++) 
         {
            scanf("%d%d",&num[i].d,&num[i].r);
            num[i].val=num[i].d-num[i].r;
          }
        sort(num+1,num+n+1,cmp);
        printf("%d\n",dp(1,f));
     }
    return 0;
}

 

posted on 2017-09-06 20:21  宣毅鸣  阅读(133)  评论(0编辑  收藏  举报