关于一棵树

119 篇文章 4 订阅
32 篇文章 0 订阅

树的直径(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[i]表示i这棵子树中,以i为端点的最长链
g[i]表示i这棵子树中,以i为端点的次长链
这样当前点对答案的贡献就是f[i]+g[i]
例题

树的重心

详解

splay
这里写图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值