浅谈树的直径

article/2025/10/7 2:09:35

一、定义

        我们将一棵树T=(V,E)的直径定义为max(u,v) (u,v∈V),也就是说,树中所有最短路径距离的最大值即为树的直径。(就是树中的最长路径的长度)


二、求解树德直径

        求得树的直径有两种方法,一种是两边 bfs (或者两边dfs)就能搞定的算法。还有一种就是树形DP。我们先来了解第一种,就是两遍dfs(或bfs)的算法。

        引理:对于树上任意一点 P,找到离它最远的节点 Q。在找到离节点 Q 最远的节点 W。路径WQ的长度就是树的直径。

        下面我们来证明这个引理。我们将证明分为3种情况。

                1):点 P 本身就在直径上,所以很容易知道 Q 也在直径上且为直径的一个端点。

                2):点 P 不在树的直径上,但假设存在不是 WQ 的树的直径 AB 与路径 PQ有一个交点 C,如下图。反证法:因为 PQ 为最远,所以 PC + CQ > PC + CA 进而可以得到 CQ > CA。不等式两边同时加上BC,得到 CQ + BC > CA + BC = AB。 这个结论与 AB 为直径的假设不符,故假设不成立。 

                3):点 P 不在树的直径上,并且假设存树的直径不是 WQ 而是 AB,且 AB 与 PQ 没有交点,如下图。因为 PQ 为最远,所以 NP + NQ > NQ + MN + MB,进而得到 NP > MN + MB。易得 NP + MN > MB。不等式两边同时加上 AM 得 NP + MN + AM > MB + AM = AB。与 AB为树的直径的前提相矛盾。所以假设不成立。

         综上所述,引理成立,证毕。

         既然我们已经知道了引理,那么要求出树的直径也就很简单了,两边 dfs(或 bfs)就行了。代码如下:

#include<bits/stdc++.h>
using namespace std;#define MAXN 100100
#define MAXM 2 * MAXNint n = 0; int m = 0;int tot = 0;
int first[MAXN] = { 0 };
int   nxt[MAXM] = { 0 };
int    to[MAXM] = { 0 };
int value[MAXM] = { 0 };void add(int x, int y , int weight){nxt[++tot] = first[x];first[x] = tot; to[tot] = y;value[tot] = weight;
}int p = 0; int ans = 0;
int dis[MAXN] = { 0 };
void dfs(int x, int fa){for(int e = first[x]; e; e = nxt[e]){int y = to[e];if(y == fa){continue;}dis[y] = dis[x] + value[e];if(ans < dis[y]){ans = dis[y];p = y;}dfs(y, x);}
}int main(){scanf("%d%d", &n, &m);for(int i = 1; i <= m; i++){int x = 0; int y = 0; int w = 0;scanf("%d%d%d", &x, &y, &w);add(x, y, w);add(y, x, w);}ans = 0;dis[1] = 0;dfs(1, 0);ans = 0;dis[p] = 0;dfs(p, 0);printf("%d\n", ans);return 0;
}


        接下来是第二种方法:树形DP(玄学的方法qwq):

        我们需要俩数组,一个 f1[MAXN],一个f2[MAXN]。分别表示在以 i 节点为根的子树中,i 到叶节点的距离的最大值和次大值。然后就是显而易见玄学的动归方程了(其中w[i][j] 表示 i 到 j 的边权):

                                        if(f1[i] < f1[j] + w[i][j])   f2[i] = f1[i], f1[i] = f1[j] + w[i][j]

                                        else if(f2[i] < f1[j] + w[i][j])   f2[i] = f2[j] + w[i][j]

        原理其实很简单(说他玄学是因为不知道是谁那么聪明想出来的这玩意儿)。就是说我们尝试去更新 f1[i] ,如果可以更新,那我们让 f2[i] = f1[i] 刚才的最大值为现在的次大值,然后再更新f1[i]。否则,我们尝试更新 f2[i] 如果能更新,就更新。如果不能,就不管他。

        我们得到这俩数组之后,树的直径很显然就是 \max_{i=1}^{n} (f1_i + f2_i) 了。

 

        然后就是代码:

#include<bits/stdc++.h>
using namespace std;#define MAXN 1001000
#define MAXM 2 * MAXNint n = 0; int m = 0;int tot = 0;
int first[MAXN] = { 0 };
int   nxt[MAXM] = { 0 };
int    to[MAXM] = { 0 };
int value[MAXM] = { 0 };void add(int x, int y, int weight){nxt[++tot] = first[x];first[x] = tot;to[tot] = y;value[tot] = weight;
}int ans = 0;
int f1[MAXN] = { 0 };
int f2[MAXN] = { 0 };void dp(int x, int fa){for(int e = first[x]; e; e = nxt[e]){int y = to[e];if(y == fa){continue;}dp(y, x);if(f1[x] < f1[y] + value[e]){f2[x] = f1[x];f1[x] = f1[y] + value[e];}else if(f2[x] < f1[y] + value[e]){f2[x] = f1[y] + value[e];}ans = max(ans, f1[x] + f2[x]); }
}int main(){scanf("%d", &n);for(int i = 1; i <= n-1; i++){int x = 0; int y = 0; int w = 0;scanf("%d%d%d", &x, &y, &w);add(x, y, w); add(y, x, w);}dp(1, 0);printf("%d\n", ans);return 0;
}


http://chatgpt.dhexx.cn/article/aQEU0FdO.shtml

相关文章

3.网络基础-三层路由网络

3.1、IP地址 初识IP地址 • 在IP网络中&#xff0c;通信节点需要有一个唯一的IP地址&#xff1b; • IP地址用于IP报文的寻址以及标识一个节点&#xff1b; • IPv4地址一共32bits&#xff0c;使用点分十进制的形式表示&#xff1b; IP地址的分类 E类是保留地址 公有IP及私有…

计算机网络——配置动态路由实验

配置动态路由实验 实验目的实验软件实验要求实验知识实验步骤实验结果 实验目的 掌握 RIP 协议配置。RIP 协议配置的命令为&#xff1a;router(config)#network <connected-network> 其中参数 <connected-network> 表示路由器的直连网络号。 实验软件 Cisco Pac…

路由技术基础

路由技术是在网络拓扑结构中为不同节点的数据提供传输路径的技术&#xff0c;路由选择算法是其核心内容。路由选择算法分为静态路由选择算法和动态路由选择算法。 一.路由基础 1.路由的基本概念 路由、路由器 &#xff08;1&#xff09;路由 路由是指导IP报文从源发送到目…

网络路由交换 -- 静态路由 和 缺省路由

1.IP路由基础 1.什么是静态路由&#xff1f; 静态路由是由管理员手工添加的路由条目&#xff1b;通过静态路由添加的都是非直连网段。 2.静态路由的特点&#xff1f; 静态路由的添加和删除都需要手工完成&#xff1b;静态路由无法适应网络的动态变更&#xff0c;即缺乏适应…

cisco packet tracer配置网络路由

广州大学 计算机网络实验 配置网络路由 利用packet tracer搭建如图网络 中间是三个路由器&#xff0c;两边各接一台计算机。 首先先把网络搭建出来 1是路由器&#xff0c;2是终端设备&#xff0c;3是连接设备的线缆。左键点击1或者2或3&#xff0c;区域4就会出现不同的路由器…

路由的几个基本概念-直连路由/网关路由/主机路由/网络路由/动态路由/静态路由/默认路由

1.动态路由/静态路由 1&#xff09;动态路由 路由选择器自动共享路由信息 自动构造路由表&#xff0c;需要一个路由协议&#xff0c;如RIP或OSPF 2&#xff09;静态路由 路由选择器不共享路由信息&#xff08;单方向路由&#xff09; 手工构造路由表 2.直连路由/网关路由…

计算机网络-实验四:配置网络路由

一、实验目的 了解路由器的特点、基本功能及配置方法&#xff1b;使用模拟软件Packet Tracer 8.0&#xff0c;熟悉Cisco路由器的操作&#xff1b;配置静态路由和距离矢量路由协议RIP&#xff0c;实现给定网络的连通&#xff1b;从而加深对IP编址、路由转发机制、路由协议、路由…

广州大学 计算机网络实验 2020版 配置网络路由

一、实验目的 了解路由器的特点、基本功能及配置方法&#xff1b;使用模拟软件 Packet Tracer 5.3 熟悉 Cisco 路由器的操 作&#xff1b;配置静态路由和距离矢量路由协议 RIP&#xff0c;实现给定网络的连通&#xff1b;从而加深对IP 编址、路由转发机制、路由协 议、路由表的…

Ad hoc网络路由协议概述1——分类

目录 1. 传统Internet网络路由协议 1.1 距离矢量路由协议&#xff08;Distance Vector&#xff09; 1.2 链路状态路由协议&#xff08;Link State&#xff09; 1.3 在Ad hoc网络中的不适用性 1.3.1 动态变化的网络拓扑结构 1.3.2 周期性的广播拓扑信息 1.3.3 单向的无线…

3.2 Ad Hoc 网络路由协议

Ad Hoc 网络路由协议 Ad Hoc 网络路由面临的问题 在设计Ad Hoc 网络路由协议时&#xff0c;我们首先要明确可能面临的问题&#xff1a; &#xff08;1&#xff09;路由信息不易获得&#xff1a;定期交换路由信息的开销大、网络资源有限&#xff0c;并且必须被所有节点共享、节…

Ad hoc网络路由协议概述2——表驱动路由协议(1)DSDV协议(Destination-sequenced distance vector protocol)

目录 1 DSDV协议的先导协议: DV协议的困境 2 解决DV协议计数到无穷的困境 2.1 毒性反转 (Poisoned reverse) 2.2 增加序列号 3 DSDV协议 3.1 基本流程 3.2 广播机制 3.2.1 交换路由信息的两个时刻 3.2.2 交换路由信息的两种方式 3.2.3 序列号不同如何选择 3.2.4 序列…

Ad hoc网络路由协议概述4——按需路由协议(2)AODV协议 (Ad-hoc on-demand distance vector algorithm protocol)

目录 1 一点前言 2 路由发现 2.1 相关概念 2.2 AODV的路由发现过程 2.3 与DSDV协议的对比 3 路由表管理及维护 3.1 更新路由表的策略 4 AODV协议的特点 4.1 优点 4.2 缺点 1 一点前言 在之前提过的DSR协议中&#xff0c;采用了源节点路由方式&#xff0c;每个数据报…

计算机网络实验四:配置网络路由

1、相关知识点 1.1 路由器的一般知识&#xff1a; 路由器是局域网与广域网之间进行互联的关键设备。通过它不仅可以互联不同协议、不 同物理接口的网络&#xff0c;还能选择数据传送的路经&#xff0c;并能阻隔非法访问。它在异构网互联能力、 拥塞控制能力和网段的隔离能力等方…

linux 默认路由 主机路由 网络路由

route命令 oute 命令的输出项说明 输出项 说明 Destination目标网段或者主机Gateway网关地址&#xff0c;”*” 表示目标是本主机所属的网络&#xff0c;不需要路由Genmask网络掩码Flags标记。一些可能的标记如下&#xff1a; U — 路由是活动的 H — 目标是一个主机 G — 路…

计算机网络路由转发题

1&#xff09;、目的地址和142.150.64.0/24明显不匹配&#xff0c;所以只有B、C、D&#xff0c;把相应的网络地址算出来 B-网络地址&#xff1a;142.150.71.128 C-网络地址&#xff1a;142.150.71.128 D-网络地址&#xff1a;142.150.0.0&#xff0c;把目的地址逐条的和子网…

各种路由的概念-直连路由、网关路由、主机路由、网络路由等

各种路由的概念 路由的分类 直连路由在添加的时候使用的是出接口&#xff08;dev&#xff09; 网关路由在添加的时候使用的是下一跳&#xff08;gw&#xff09; 主机路由的目的地址是一个完整的主机地址&#xff08;host&#xff09; 网络路由的目的地址是一个网络地址&#…

片上网络路由算法综述

一、 片上网络概述 在半个多世纪以来&#xff0c;半导体工业一直遵循着“摩尔定律”发展&#xff0c;即集成电路上可容纳的晶体管数目&#xff0c;约每隔两年便会增加一倍。截至目前&#xff0c;处理器中的晶体管数量最多已达到了上百亿。晶体管数量的增加一方面极大提升了单核…

网络——路由

路由 路由是路由器控制层面的工作&#xff08;路由器另一工作是数据层面上的转发&#xff09;&#xff0c;所以路由的学习需要从路由器入手。 借鉴学习&#xff1a;路由器工作原理 设备-路由器 路由器含义结构功能工作原理工作在OSI模型的网络层上的具有多个输入端口和多个输…

网络基础之路由详解

目录 IP路由基础 路由协议的分类 路由选路规则 静态路由 缺省路由 OSPF开放式最短路径优先协议 IP路由基础 路由器 特点 路由器的一个接口就是一个网段&#xff0c;一个网段就是一个广播域 路由器的一个接口用于一个MAC地址 路由器可以隔离广播域 广播报文无法穿越…

计算机网络:路由的概念及其分类

面对“路由”二字&#xff0c;很多人的第一个反应就是路由器。而路由器只是实现“路由”这一功能的工具罢了。路由器可以说是一台简化的电脑&#xff0c;它具有操作系统&#xff0c;接口&#xff0c;输入输出&#xff0c;存储器等等。正因为如此&#xff0c;现代路由器和电脑一…