OpenJudge 2631:Roads in the North(树的直径)
树的直径:树的最长路.
显然若为无权值的无向图,树的直径就是边最多的一条路,若为有权无向图,树的直径就是权值总和最大的一条边
思路:遍历整棵树,从任意点出发,求出每个节点向下走的最大长度d1次大长度d2,则经过每个点的最长路为d1+d2,求出所有点最长路中的最大值即为直径
性质:一棵树中,一个点必然与直径的两个端点中的一个相距最远

#include <set> #include <iostream> #include <cstdio> #include <cstring> #include <string> #include <map> #include <algorithm> #include <stack> using namespace std; typedef long long ll; const int N = 1e4 + 5; const int inf = 0x3f3f3f3f; const int M=N*2; int h[N]; int e[M]; int w[M]; int ne[M]; int idx; int ans=0; void add(int a, int b,int c) { w[idx]=c; e[idx] = b; ne[idx] = h[a]; h[a] = idx++; } int dfs(int u,int father) { int dist=0;//当前点往下走最大长度 int d1=0,d2=0;//最大距离d1,次大距离d2; for(int i=h[u];~i;i=ne[i]) { int j=e[i]; if(j==father) { continue; } int d=dfs(j,u)+w[i]; dist=max(dist,d); if(d>d1)d2=d1,d1=d; else if(d>d2) { d2=d; } } ans=max(ans,d1+d2); return dist; } int main() { memset(h,-1,sizeof(h)); int n=0; int a,b,c; while(cin>>a>>b>>c) { add(a,b,c); add(b,a,c); } dfs(1,-1); cout<<ans<<endl; return 0; }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律