当前位置: 代码迷 >> 综合 >> POJ 3624 Charm Bracelet(01背包)
  详细解决方案

POJ 3624 Charm Bracelet(01背包)

热度:56   发布时间:2023-12-08 11:08:15.0

题目链接:
POJ 3624 Charm Bracelet
分析:
跟上一题一样。

//508K 297MS
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
const int MAX_N=35000;//数组需要开大点,3500RE...int n,v;
int val[MAX_N],cost[MAX_N],dp[MAX_N];int main()
{while(~scanf("%d%d",&n,&v)){for(int i=1;i<=n;i++){scanf("%d%d",&cost[i],&val[i]);}memset(dp,0,sizeof(dp));for(int i=1;i<=n;i++){for(int j=v;j>=cost[i];j--){dp[j]=max(dp[j],dp[j-cost[i]]+val[i]);printf("i=%d j=%d dp[j]=%d\n",i,j,dp[j]);}}printf("%d\n",dp[v]);}return 0;
}