社区讨论

听灌多

灌水区参与者 4已保存回复 8

讨论操作

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

当前回复
8 条
当前快照
1 份
快照标识符
@lzkwj1gl
此快照首次捕获于
2024/08/08 14:33
2 年前
此快照最后确认于
2024/08/08 15:25
2 年前
查看原帖
树的直径球调
CPP
//树の直径
#include<iostream>
#include<vector>
#include<cstring>

using namespace std;
typedef long long LL;

int n;
vector <int> e[1145141];
int dis[1145141];
int c;
int vis[1145141];
void dfs(int u){
	for(int i=0;i<e[u].size();i++){
		if(vis[i]) continue;
		vis[i]=1;
		dis[i]=dis[u]+1;
		if(dis[i]>dis[c]) c=i;
		dfs(i);
//		vis[i]=0;
	}
}

int main(){
	
	cin>>n;
	for(int i=1;i<n;i++){
		int x,y;
		cin>>x>>y;
		e[x].push_back(y);
		e[y].push_back(x);
	}
	dfs(1);
	dis[c]=0;
	dfs(c);
	cout<<dis[c];
	
	return 0;
}

回复

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

正在加载回复...