关于一棵树

树的直径(Diameter)是指树上的最长简单路:

一棵n个点的树,每条边都有边权w,
求一条路径使得它的权值和最大

一、边权保证非负

直径的求法:两遍BFS (or DFS)

任选一点u为起点,对树进行BFS遍历,找出离u最远(权值最大)的点v
再以v为起点,再进行BFS遍历,找出离v最远(权值最大)的点w
则v到w的路径长度(权值)即为树的直径
于是原问题可以在O(E)时间内求出

简单证明
关键在于证明第一次遍历的正确性,
也就是对于任意点u,距离它最远的点v一定是最长路的一端

如果u在最长路上,那么v一定是最长路的一端
可以用反证法:假设v不是最长路的一端,则存在另一点v’使得(u→v’)是最长路的一部分,
于是len(u→v’) > len(u→v)
但这与条件“v是距u最远的点”矛盾

如果u不在最长路上,则u到其距最远点v的路与最长路一定有一交点c,
且(c→v)与最长路的半段重合,
即v一定是最长路的一端

二、边权为Z
设计状态f[u]表示在u为根的子树中,经过u的最大路径的边权和
(u可以是路径的端点也可以是中间的点)
g[u]表示在u为根的子树中,存在点u的最大路径的边权和
(u只能是路径端点)

fa=pre[u]

f[fa]=max(firstmax{w(fa,u)+g[u]},0)

+max(secondmax{w(fa,u)+g[u]},0)

g[fa]=max{w(fa,u)+g[u]}

树的重心

http://blog.csdn.net/pi9nc/article/details/12394117

spaly
这里写图片描述

原文地址:https://www.cnblogs.com/wutongtong3117/p/7673462.html