社区讨论

70pts悬关!

P10111[GESP202312 七级] 纸牌游戏参与者 1已保存回复 0

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
0 条
当前快照
1 份
快照标识符
@lxagd5f1
此快照首次捕获于
2024/06/11 21:43
2 年前
此快照最后确认于
2024/06/12 14:23
2 年前
查看原帖
CPP
#include<bits/stdc++.h>
using namespace std;
int dp[1005][1005][5]/*[第几局][换了几次牌][当前的纸牌]*/,n,a[1005],b[1005],c[1005];
int main(){
	cin>>n;
	for(int i=1;i<=n;i++)
		cin>>a[i];
	for(int i=1;i<n;i++)
		cin>>b[i];
	for(int i=1;i<=n;i++)
		cin>>c[i];
	for(int i=1;i<=n;i++)
		for(int j=0;j<i;j++){
			int cnt[5]={0,0,0,0,0};
			if(c[i]==0)cnt[0]=a[i],cnt[1]=a[i]*2;
			else if(c[i]==1)cnt[1]=a[i],cnt[2]=a[i]*2;
			else cnt[2]=a[i],cnt[0]=a[i]*2;
			for(int k=0;k<3;k++){
				dp[i][j][k]=cnt[k]+dp[i-1][j][k];
				if(j!=0){
					int x,y;
					if(k==0)x=1,y=2;
					else if(k==1)x=0,y=2;
					else x=0,y=1;
					dp[i][j][k]=max(dp[i][j][k],max(cnt[k]+dp[i-1][j-1][x]-b[j],cnt[k]+dp[i-1][j-1][y]-b[j]));
				}
			}
		}
	int maxx=-100000000;
	for(int i=0;i<3;i++)
		for(int j=0;j<n;j++)
			maxx=max(dp[n][j][i],maxx);
	cout<<maxx;
	return 0;
}

回复

0 条回复,欢迎继续交流。

正在加载回复...