思路大众,马蜂较好,求调
查看原帖
思路大众,马蜂较好,求调
1114327
wantto123楼主2024/10/10 21:54
#include<bits/stdc++.h>
using namespace std;
const int N=65;
int f[N],w[N],v[N],p[N][N];
int n,m,ans,k;
int main(){
	cin>>n>>m;
	for(int i=1;i<=m;i++) {
		cin>>w[i]>>v[i]>>k;
		if(k!=0) {
			if(p[k][1]==0) p[k][1]=i;
			else p[k][2]=i;					
		}
	}
	for(int i=1;i<=m;i++){
		for(int j=n;j>=w[i];j--){
			if(j-w[i]>=0) 
				f[j]=max(f[j],f[j-w[i]]+w[i]*v[i]);
				
			if(p[i][1]!=0){
				if(j-w[i]-w[p[i][1]]>=0) 
					f[j]=max(f[j],f[j-w[i]-w[p[i][1]]]+w[i]*v[i]+w[p[i][1]]*v[p[i][1]]);
					
				if(p[i][2]!=0){
					if(j-w[i]-w[p[i][2]]>=0) 
						f[j]=max(f[j],f[j-w[i]-w[p[i][2]]]+w[i]*v[i]+w[p[i][2]]*v[p[i][2]]);
					if(j-w[i]-w[p[i][1]]-w[p[i][2]]>=0) 
						f[j]=max(f[j],f[j-w[i]-w[p[i][1]]-w[p[i][2]]]+w[i]*v[i]+w[p[i][1]]*v[p[i][1]]+w[p[i][2]]*v[p[i][2]]);
				}
				
			}	
			
		}
	}
	for(int i=0;i<=n;i++) ans=max(ans,f[i]);
	cout<<ans;
	return 0;
}
2024/10/10 21:54
加载中...