求大佬给找一下错 总是wa4个点(金明的预算方案)

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

as2236932821 @ 2018-10-07 19:05:44



#include<iostream>
#include<cstdio>
#include<cmath>
#include<cstring>

using namespace std;
int n,m;

int dp[310000];
int v[1000][3],p[1000][3];
int main()
{
    cin>>n>>m;
    int num=0;
    for(int i=1;i<=m;i++)
    {
        int x,y,z;
        cin>>x>>y>>z;
        if(!z)
        {
            v[++num][0]=x;
            p[num][0]=x*y;
        }
        else
        {
            if(v[z][1])
            {
                v[z][2]=x;
                p[z][2]=x*y;
            }
            else 
            {
                v[z][1]=x;
                p[z][1]=x*y;
            }
        }
    }
    for(int i=1;i<=num;i++)
    for(int j=n;j>=v[i][0];j--)
    {
        dp[j]=max(dp[j],dp[j-v[i][0]]+p[i][0]);
        if(v[i][1]&&j>=v[i][0]+v[i][1])
        dp[j]=max(dp[j],dp[j-v[i][0]-v[i][1]]+p[i][0]+p[i][1]);
         if(v[i][2]&&j>=v[i][0]+v[i][2])
        dp[j]=max(dp[j],dp[j-v[i][0]-v[i][2]]+p[i][0]+p[i][2]);
         if(v[i][2]&&v[i][1]&&j>=v[i][0]+v[i][1]+v[i][2])
        dp[j]=max(dp[j],dp[j-v[i][0]-v[i][1]-v[i][2]]+p[i][0]+p[i][1]+p[i][2]);

    }

    cout<<dp[n];

    return 0;
}```

by L1ttel_Y @ 2018-10-18 20:10:07

同哇4


|