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
蟹蟹大佬喵