40分求调玄关喵))

P1064 [NOIP2006 提高组] 金明的预算方案

maimai_slide_madman @ 2024-08-13 08:58:52

WA on #4~#9喵

#include<bits/stdc++.h>
using namespace std;
long long n,m,x;
long long w[50000],v[50000],p[50000][3],dp[50000];
int main(){
    cin>>n>>m;
    for(int i=1;i<=m;i++){
        cin>>w[i]>>v[i]>>x;
        v[i]*=w[i];
        if(x==0) p[i][0]=1;
        else if(!p[x][1]) p[x][1]=i;
        else p[x][2]=i;
    }
    dp[0]=0;
    for(int i=1;i<=m;i++){
        for(int j=n;j>=w[i];j--){
            if(!p[i][0]) continue;

            dp[j]=max(dp[j],dp[j-w[i]]+v[i]);

            if(j-w[i]>=w[p[i][1]])
                dp[j]=max(dp[j],dp[j-w[i]-w[p[i][1]]]+v[i]+v[p[i][1]]);

            if(j-w[i]>=w[p[i][2]])
                dp[j]=max(dp[j],dp[j-w[i]-w[p[i][2]]]+v[i]+v[p[i][2]]);

            if(j-w[i]>=w[p[i][1]]+w[p[i][2]])   
                dp[j]=max(dp[j],dp[j-w[i]-w[p[i][1]]-w[p[i][2]]]+v[p[i][1]]+v[p[i][2]]);

        }
    }
    cout<<dp[n];

    return 0;
} 

为什么呀喵???


by vorDeal @ 2024-08-13 09:17:51

最后的答案是求 DP 数组的 max,因为可能压根买不到 n 元。 @maimai_slide_madman


by maimai_slide_madman @ 2024-08-13 09:24:31

@vorDeal 不是哪喵

别人帮我改了,是循环里最后一种情况少写了个+v[i]呢喵

谢谢,已关喵


by 鶴守丶葉七 @ 2024-08-13 09:28:07

@maimai_slide_madman
最后一种条件若都能选取还要加上主件的价值 v[i]

dp[j]=max(dp[j],dp[j-w[i]-w[p[i][1]]-w[p[i][2]]]+v[p[i][1]]+v[p[i][2]]+v[i]);

by 鶴守丶葉七 @ 2024-08-13 09:28:21

啊抱歉没刷新没看到已经解决了


by maimai_slide_madman @ 2024-08-13 09:39:08

@Meteor_Vi

蟹蟹大佬喵


|