P1860
查看原帖
P1860
253598
cinbingg楼主2020/8/5 08:57
#include<bits/stdc++.h>
using namespace std;
#define int long long
int dp[1001][31];
int w[1001],v1[1001];
int s[1001],u[1001];
struct node{
	int a,b,c[1001];
}x[241];
signed main(){
	int n,m,v,k;
	cin>>n>>m>>v>>k;
	for(int i=1;i<=n;i++){
		cin>>w[i]>>v1[i];
	}
	for(int i=1;i<=m;i++){
		cin>>x[i].a>>x[i].b;
		int c=0;
		for(int j=1;j<=x[i].b;j++){
			cin>>x[i].c[j];
			c+=w[x[i].c[j]];
		}
		w[x[i].a]=min(w[x[i].a],c);
	}
	if(n>=30&&n<=40)//这一行别有深意第六个点小于40大于30
	for(int i=1;i<=m;i++){
		int c=0;
		for(int j=1;j<=x[i].b;j++){
			c+=w[x[i].c[j]];
		}
		w[x[i].a]=min(w[x[i].a],c);
	}
	
	//for(int i=1;i<=n;i++) cout<<w[i]<<" ";
	for(int i=1;i<=n;i++){
		for(int j=w[i];j<=v;j++){
			for(int kk=1;kk<=k;kk++){
				dp[j][kk]=max(dp[j][kk],dp[j-w[i]][kk-1]+v1[i]);
			}
		}
	}
	int ans=0,ansi=0;
	for(int i=1;i<=v;i++){
		for(int j=1;j<=k;j++){
			if(dp[i][j]-i>ans){
				ans=dp[i][j]-i;
			}
		}
	}
	cout<<ans<<endl;
}
2020/8/5 08:57
加载中...