--hdu 2602 Bone Collector (01背包)

 

#include<bits/stdc++.h>
using namespace std;
int main()
{
    int c;
    scanf("%d",&c);
    while(c--)
    {
        int n,v,dp[1004],a[1004],b[1004];
        memset(dp,0,sizeof(dp));
        scanf("%d%d",&n,&v);
        for(int i=0; i<n; i++)
            scanf("%d",&a[i]);
        for(int i=0; i<n; i++)
            scanf("%d",&b[i]);
        for(int i=0; i<n; i++)
            for(int j=v; j>=b[i]; j--)

                dp[j]=max(dp[j],dp[j-b[i]]+a[i]);
        printf("%d\n",dp[v]);
    }
    return 0;
}

 

posted @ 2016-08-11 23:27  马丁黄瓜啊  阅读(95)  评论(0编辑  收藏  举报