zoukankan      html  css  js  c++  java
  • 关于一棵树

    树的直径(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
    这里写图片描述

  • 相关阅读:
    生成函数初步
    Lg 8月赛(构造+交互)
    wqs 二分学习笔记
    FastAPI 学习之路(十六)Form表单
    线性代数入门
    Oracle-PDB拔插
    MySQL-audit审计插件
    MySQL-用户与权限管理
    MySQL-存储引擎
    MySQL-逻辑结构
  • 原文地址:https://www.cnblogs.com/wutongtong3117/p/7673463.html
Copyright © 2011-2022 走看看