社区讨论

求助,为什么k=0 dfs期望45,洛谷爆0,附代码

P8817[CSP-S 2022] 假期计划参与者 5已保存回复 4

讨论操作

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

当前回复
4 条
当前快照
1 份
快照标识符
@lo7o2wi8
此快照首次捕获于
2023/10/27 04:58
2 年前
此快照最后确认于
2023/10/27 04:58
2 年前
查看原帖
CPP
#include<bits/stdc++.h>
using namespace std;
int n,m,k;int x,y;int ans;
vector<int>a[2550];int d[2550];
bool vis[2550];bool dis[2550];
void dfs(int x,int val,int cnt){
	//cout<<cnt<<endl;
	if(cnt==4){
		if(vis[x]==1){
			
			ans=max(ans,val);
		}
		return ;
	}
	for(int i=0;i<a[x].size();i++){
		if(dis[a[x][i]]==0){
			dis[a[x][i]]=1;
			dfs(a[x][i],val+d[a[x][i]],cnt+1);
			dis[a[x][i]]=0;
		}
	}
}
signed main(){
	cin>>n>>m>>k;
	for(int i=2;i<=n;i++) cin>>d[i];
	for(int i=1;i<=m;i++){
		cin>>x>>y;
		a[x].push_back(y);
		a[y].push_back(x);
	}
	for(int i=0;i<a[1].size();i++){
		vis[a[1][i]]=1;
	}
	dfs(1,0,0);
	cout<<ans;
	return 0;
}

回复

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

正在加载回复...