[模板]树的最长路径

news/2024/11/15 0:28:16/

[模板]树的最长路径

题目描述

给定一棵树,树中包含 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

#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

#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
*/


http://www.ppmy.cn/news/1527574.html

相关文章

Day04_JVM实战

文章目录 一、gc日志和dump快照GC日志是什么,要怎么看?dump快照是什么?要怎么看?二、gc日志和dump快照实战java.lang.OutOfMemoryError:Java heap space1、gc.log怎么看2、heapdump.hprof怎么看?①jvisualvm查看②使用MAT查看java.lang.OutOfMemoryError:Metaspace1、实时…

学懂C++(六十):C++ 11、C++ 14、C++ 17、C++ 20新特性大总结(万字详解大全)

一、引言 随着计算机科学与技术的飞速发展&#xff0c;编程语言也在不断进化以满足日益增长的需求。C是一门集高性能和灵活性于一身的编程语言&#xff0c;自1983年诞生以来不断演进&#xff0c;逐渐成为了众多领域的主流编程语言。为了进一步提升开发效率和代码质量&#xff0…

LeetCode-137. 只出现一次的数字 II【位运算 数组】

LeetCode-137. 只出现一次的数字 II【位运算 数组】 题目描述&#xff1a;解题思路一&#xff1a;解题思路二&#xff1a;符号位一起判断。背诵版解题思路三&#xff1a;0 题目描述&#xff1a; 给你一个整数数组 nums &#xff0c;除某个元素仅出现 一次 外&#xff0c;其余每…

C#基础(11)函数重载

前言 前面我们已经完成了ref和out补充知识点的学习&#xff0c;以及函数参数相关的学习&#xff0c;今天便再次为函数补充一个知识点&#xff1a;函数重载。 函数重载是指在同一个作用域中&#xff0c;可以有多个同名函数&#xff0c;但参数列表不同。它的发展可以追溯到早期…

02 ETH

以太坊与比特币有什么不同&#xff1f; 以太坊立足比特币创新之上&#xff0c;于 2015 年启动&#xff0c;两者之间有一些显著不同。 比特币就仅仅是比特币&#xff1b;以太坊包括以太币&#xff0c;以太币才是和比特币对等的存在。以太坊是可编程的&#xff0c;所以你可以在…

本地镜像发布到阿里云

本地镜像发布到阿里云 登录阿里云容器镜像服务配置 Docker 登录阿里云容器镜像服务标记你的 Docker 镜像推送镜像到阿里云验证使用阿里云镜像注意事项 将 Docker 本地镜像发布到阿里云&#xff08;Alibaba Cloud&#xff09;容器镜像服务&#xff08;Container Registry&#x…

Linux运维篇-服务器简介

目录 前言服务器分类&#xff08;按服务器的机箱结构来划分&#xff09;台式服务器机架式服务器刀片式服务器 外观部件内部结构前面板前面板组件前面板接口说明前面板指示灯和按钮前面板指示灯/按钮说明 后面板后面板组件后面板接口说明后面板指示灯后面板指示灯说明 主板和 iB…

浅谈openresty

熟悉了nginx后再来看openresty&#xff0c;不得不说openresty是比较优秀的。 对nginx和openresty的历史等在这此就不介绍了。 首先对标nginx&#xff0c;自然有优劣 一、开发难度 nginx&#xff1a; 毫无疑问nginx的开发难度比较高&#xff0c;需要扎实的c/c基础&#xff…