20分求助

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

小超手123 @ 2022-07-18 10:00:07

#include<bits/stdc++.h>
using namespace std;
int n,m,ans;
int a[100][5]; 
int w[100],c[100];
int dp[100][100005];
bool f[100];
int find(int i){
    for(int j=i-1;j>=1;j--){
        if(f[j]==1)return j;
    }
    return 0;
}
int main(){
    cin>>m>>n;
    for(int i=1;i<=n;i++){
        cin>>w[i]>>c[i];
        int x;
        cin>>x;
        if(x!=0){
            a[x][0]++;
            a[x][a[x][0]]=i; //记录附件 
        }else{
            f[i]=1;
        }
    }
    for(int i=1;i<=n;i++){
        for(int j=0;j<=a[i][0];j++)cout<<a[i][j]<<" ";
        cout<<endl; 
    }
    for(int i=1;i<=n;i++){
        if(f[i]==1){ //它是主件 
            for(int j=0;j<=m;j++){
                int last=find(i);  //上一个主件的编号 
                if(j<w[i]){//主件都买不起
                    dp[i][j]=dp[last][j];
                    continue;
                }

                dp[i][j]=max(dp[last][j-w[i]]+w[i]*c[i],dp[last][j]); 

                if(a[i][0]>=1&&j>=w[i]+w[a[i][1]])
                    dp[i][j]=max(dp[i][j],dp[last][j-w[i]-w[a[i][1]]]+w[i]*c[i]+w[a[i][1]]*c[a[i][1]]);
                if(a[i][0]>=2&&j>=w[i]+w[a[i][2]])
                    dp[i][j]=max(dp[i][j],dp[last][j-w[i]-w[a[i][2]]]+w[i]*c[i]+w[a[i][2]]*c[a[i][2]]); 
                if(a[i][0]>=3&&j>=w[i]+w[a[i][3]])
                    dp[i][j]=max(dp[i][j],dp[last][j-w[i]-w[a[i][3]]]+w[i]*c[i]+w[a[i][3]]*c[a[i][3]]);

            }
        }
    }
    for(int i=0;i<=m;i++)ans=max(ans,dp[n][i]);
    cout<<ans;
    return 0;
}
/*
10 3
5 2 0
3 2 1
3 1 1
*/ 

by 小超手123 @ 2022-07-18 10:01:05

代码末尾的样例它输出0


by tjer @ 2022-07-18 11:03:43

ljm做jm的预算方案(


|