社区讨论

求助

P1352没有上司的舞会参与者 3已保存回复 3

讨论操作

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

当前回复
3 条
当前快照
1 份
快照标识符
@lo82lds5
此快照首次捕获于
2023/10/27 11:45
2 年前
此快照最后确认于
2023/10/27 11:45
2 年前
查看原帖
代码如下
CPP
#include<bits/stdc++.h>
#define ZYQ int(6*1e3+1)
using namespace std;
int n;
int r[ZYQ];
int f[ZYQ];
int ans=-1;
int lll[ZYQ][ZYQ];
int dfs(int x,int now){
	if(x>n)return ans;
	if(now>ans)ans=now;

	if(!lll[ZYQ][ZYQ]){
		int TMP=0;
		for(int i=x+1;i<=n;i++){
			if(f[x]!=i){
				TMP+=dfs(i,now+r[x]);
			}
		}
		lll[ZYQ][ZYQ]=ans+TMP;
		
	}
	else return lll[x][now];

}
int main(){
	scanf("%d",&n);
	for(int i=1;i<=n;i++){
		scanf("%d",&r[i]);
	}
	int l,k;
	for(int i=1;i<=n-1;i++){
		scanf("%d",&l,&k);
		f[l]=k;
	}
	dfs(1,0);
	printf("%d",ans);
	return 0; 
}
第一组测试数据输出6,一年没碰OI找不到问题 谢!

回复

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

正在加载回复...