[模板]树的最长路径

[模板]树的最长路径

题目描述

给定一棵树,树中包含 n 个结点(编号1~n)和 n-1 条无向边,每条边都有一个权值。

现在请你找到树中的一条最长路径。

换句话说,要找到一条路径,使得使得路径两端的点的距离最远。

注意:路径中可以只包含一个点。

输入格式

第一行包含整数 n。

接下来 n-1 行,每行包含三个整数 ai,bi,ci,表示点 ai 和 bi 之间存在一条权值为 ci 的边。

输出格式

输出一个整数,表示树的最长路径的长度。

样例输入1

6

5 1 6

1 4 5

6 3 9

2 6 8

6 1 7

样例输出1

22

注释说明

1≤n≤10000,1≤ai,bi≤n,-10^5≤ci≤10^5

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
int n,f[100005],ww,maxn,maxf;
bool used[100002]; 
struct ed{
	int to,wi;
};
vector<ed>a[200002];
void dfs(int x,int fa){
	for(int i=0;i<a[x].size();i++){
		int v=a[x][i].to;
		if(v==fa)continue;
		f[v]=a[x][i].wi+f[x];
		dfs(v,x);
	}
	if(maxn<f[x]){
		maxn=f[x];
		maxf=x;
	}
}
int main(){
	scanf("%d",&n);
	for(int i=1;i<n;i++){
		int v,u;
		scanf("%d%d%d",&v,&u,&ww);
		a[v].push_back({u,ww});
		a[u].push_back({v,ww});
	}
	dfs(1,-1);
	f[maxf]=0;
	//memset(f,0,sizeof(f));
	maxn=0;
	dfs(maxf,-1);
	printf("%d\n",maxn);
	
}
/*
6
5 1 6
1 4 5
6 3 9
2 6 8
6 1 7
*/

解法一:从任意一点u出发搜到的最远的点一定是s、t中的一点,然后在从这个最远点开始搜,就可以搜到另一个最长路的端点,即用两遍广搜就可以找出树的最长路。

解法二:算是树的直径的一个性质,树的直径的长度一定会是某个点的最长距离f1[x]与次长距离f2[x]之和。最后求出max{f1[x]+f2[x]}就可以了。


版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

原文链接:https://blog.csdn.net/linzhi6236/article/details/131604008

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
int n,f1[100005],f2[100005],ww,ans;
struct ed{
	int to,wi;
};
vector<ed>a[200002];
void dfs(int x,int fa){
	f1[x]=0;
	f2[x]=0;
	for(int i=0;i<a[x].size();i++){
		int v=a[x][i].to;
		if(v==fa)continue;		
		dfs(v,x);
		if(f1[v]+a[x][i].wi>f1[x]){
			f2[x]=f1[x];
			f1[x]=f1[v]+a[x][i].wi;
		}
		else if(f1[v]+a[x][i].wi>f2[x]){
			f2[x]=f1[v]+a[x][i].wi;
		}
	}
	ans=max(ans,f1[x]+f2[x]);
}
int main(){
	scanf("%d",&n);
	for(int i=1;i<n;i++){
		int v,u;
		scanf("%d%d%d",&v,&u,&ww);
		a[v].push_back((ed){u,ww});
		a[u].push_back((ed){v,ww});
	}
	dfs(1,-1);
	printf("%d\n",ans);
	
}
/*
6
5 1 6
1 4 5
6 3 9
2 6 8
6 1 7
*/
相关推荐
Tisfy1 分钟前
LeetCode 3315.构造最小位运算数组 II:位运算
算法·leetcode·题解·位运算
YuTaoShao15 分钟前
【LeetCode 每日一题】1292. 元素和小于等于阈值的正方形的最大边长
算法·leetcode·职场和发展
Remember_99316 分钟前
【数据结构】深入理解Map和Set:从搜索树到哈希表的完整解析
java·开发语言·数据结构·算法·leetcode·哈希算法·散列表
浅念-17 分钟前
C++第一课
开发语言·c++·经验分享·笔记·学习·算法
charlie11451419120 分钟前
现代嵌入式C++教程:对象池(Object Pool)模式
开发语言·c++·学习·算法·嵌入式·现代c++·工程实践
燃于AC之乐32 分钟前
我的算法修炼之路--8——预处理、滑窗优化、前缀和哈希同余,线性dp,图+并查集与逆向图
算法·哈希算法·图论·滑动窗口·哈希表·线性dp
格林威43 分钟前
多相机重叠视场目标关联:解决ID跳变与重复计数的 8 个核心策略,附 OpenCV+Halcon 实战代码!
人工智能·数码相机·opencv·算法·计算机视觉·分类·工业相机
郝学胜-神的一滴44 分钟前
深入理解网络分层模型:数据封包与解包全解析
linux·开发语言·网络·程序人生·算法
永远都不秃头的程序员(互关)44 分钟前
【K-Means深度探索(九)】K-Means与数据预处理:特征缩放与降维的重要性!
算法·机器学习·kmeans
源代码•宸1 小时前
Golang原理剖析(逃逸分析)
经验分享·后端·算法·面试·golang··内存逃逸