求树的直径算法以及证明

news2025/1/20 21:55:31

在这里插入图片描述
以下为两次dfs(bfs)的做法以及正确性证明。

算法步骤
(1)任取树上一点S,以S为源点BFS得S到各个顶点的d值;
(2)取d值最大者之一为P,再以P为源点BFS得P到各个顶点的d值;
(3)再取d值最大者之一为Q,PQ为树的其中一条直径。
算法的时间复杂度为两次BFS用时,即 2 O ( V + E ) 2O(V+E) 2O(V+E).

正确性证明:

假设AB为树的直径,且|AB|>|PQ|.
(1)若P为A或者B,则PQ=AB,|AB|=|PQ|,矛盾;
(2)若PQ与AB相交,设交点为C,如图
在这里插入图片描述

根据算法操作(2), ∣ P Q ∣ ≥ ∣ P A ∣ , ∣ P Q ∣ ≥ ∣ P B ∣ |PQ|\geq|PA|,|PQ|\geq|PB| PQPA,PQPB,
减去公共部分得 ∣ C Q ∣ ≥ ∣ C A ∣ , ∣ C Q ∣ ≥ ∣ C B ∣ |CQ|\geq|CA|,|CQ|\geq|CB| CQCA,CQCB,
对于 ∣ A Q ∣ = ∣ A C ∣ + ∣ C Q ∣ ≥ ∣ A C ∣ + ∣ C B ∣ = ∣ A B ∣ |AQ|=|AC|+|CQ|\geq|AC|+|CB|=|AB| AQ=AC+CQAC+CB=AB,同理 ∣ B Q ∣ ≥ ∣ A B ∣ |BQ|\geq|AB| BQAB,
由于AB为直径,且 ∣ A B ∣ > ∣ P Q ∣ |AB|>|PQ| AB>PQ,只能有 ∣ C Q ∣ = ∣ C A ∣ = ∣ C B ∣ > ∣ C P ∣ |CQ|=|CA|=|CB|>|CP| CQ=CA=CB>CP,
将树视为以C为根的树,设A,B,Q,P所在子树为{A},{B},{Q},{P},
S点在{A},{B},{Q},{P}其中之一,
根据算法操作(1), ∣ S P ∣ > ∣ S A ∣ |SP|>|SA| SP>SA,S点只能在{A};
∣ S P ∣ > ∣ S B ∣ |SP|>|SB| SP>SB,S点只能在{B};
∣ S P ∣ > ∣ S Q ∣ |SP|>|SQ| SP>SQ,S点只能在{S};
综上,不存在这样的S点,矛盾;
(3)若PQ与AB无交点,则设MN为两者联络线,如图
在这里插入图片描述

根据算法操作(2), ∣ P Q ∣ ≥ ∣ P A ∣ , ∣ P Q ∣ ≥ ∣ P B ∣ |PQ|\geq|PA|,|PQ|\geq|PB| PQPA,PQPB,
减去公共部分得 ∣ N Q ∣ ≥ ∣ N A ∣ , ∣ N Q ∣ ≥ ∣ N B ∣ |NQ|\geq|NA|,|NQ|\geq|NB| NQNA,NQNB,
容易得 ∣ Q M ∣ = ∣ N Q ∣ + ∣ M N ∣ > ∣ M A ∣ |QM|=|NQ|+|MN|>|MA| QM=NQ+MN>MA,
因此, ∣ B Q ∣ = ∣ B M ∣ + ∣ Q M ∣ > ∣ B M ∣ + ∣ M A ∣ = ∣ A B ∣ |BQ|=|BM|+|QM|>|BM|+|MA|=|AB| BQ=BM+QM>BM+MA=AB,与AB为树的直径相矛盾;
综上所述,假设不成立,PQ为树的直径.


以下为老师ppt上的证明:
在这里插入图片描述
在这里插入图片描述
反证法,假设v不是直径的一个端点。 δ ( u , x ) ≥ δ ( u , w ) \delta(u,x)\geq\delta(u,w) δ(u,x)δ(u,w)的前提是不妨设路径 w → u w\rightarrow u wu x → u x\rightarrow u xu有公共点,取 w = v w=v w=v,而这与算法步骤中 δ ( u , v ) \delta(u,v) δ(u,v)最大相矛盾。
在这里插入图片描述
根据第一点图①不存在,这和我证明的第(3)点对应,但我否定了图①情况后并没有进一步推证 u v uv uv x y xy xy存在公共部分(不仅仅是我第(2)点提及只有一个交点)的情形。或者说我的证明分类讨论的对象是算法求解出的 P Q PQ PQ和假设直径 A B AB AB之间的关系,遗漏了该情形。从 ∀ u \forall u u出发讨论更容易分类。
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/47638.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Metabase学习教程:仪表盘-7

使用Metabase构建记录查找工具 如何使用Metabase构建内部查找工具来快速查找有关客户、订单或其他数据的详细信息。 我们写过人们使用Metabase的一些有趣的方式其中之一是使用Metabase作为内部或后台应用程序的解决方案,例如客户查找工具。您不必构建定制页面来查…

惠普笔记本重装系统后没有声音如何解决

​最近很多小伙伴又开始了网上冲浪的生活,但是电脑用久了难免会发生一些故障的问题,最近就有些小伙伴重装系统之后问小编自己的电脑没有声音的问题?不要慌?接下来小编教你惠普笔记本重装系统后没有声音的解决方法. 工具/原料: 系统版本:win7系统 型…

基于单片机技术的自动停车器的设计

目 录 摘 要 I Abstract II 1绪论 1 1.1课题研究背景 1 1.2国内外发展现状 1 1.3汽车自动停车器的研究目的 2 1.4课题研究的意义 2 2汽车停车器的功能设计 3 2.1汽车自动停车器的设计要求 3 2.2停车器的主要功能 3 3汽车自动停车器的硬件设计 5 3.1汽车自动停车器的硬件组成 5 …

简单的 JSONParser

最近在学习 Python 的正则表达式内容,我看的是官方的文档,在文档的最后有一个例子,勾起了我的兴趣。它是用正则表达式来制作了一个简单的词法分析器。我觉得这个东西非常有趣,以前在学校的时候,有一次作业我是手写的&a…

开源?Highcharts JS 10.3.2 | Highcharts Javascript

Highsoft 是 Highcharts Javascript 图表库及其同类产品 Highcharts Stock、Highcharts Maps 和 Highcharts Gantt 背后的公司。 Highcharts 是一个多平台图表库,它使开发人员可以轻松地将交互式图表添加到任何规模的 Web 和移动项目中。 世界上最大的 100 家公司中…

36氪专访融云CEO董晗:8年企服,6年出海,现计划成为「沙特最大科技企业」

⬆️关注文章公众号文章报名融云&艾瑞“政企数智办公研究报告及新品发布会” 若从 2001 年中国加入 WTO 算起,中国企业走向海外的进程已经持续了二十余年。但由于行业起步较晚,国内企服领域的全球化,直到今年才渐成趋势。关注【融云全球互…

aws cloudformation 理解宏的使用

资料 使用 AWS CloudFormation 宏对模板执行自定义处理Macros Examples使用 AWS Lambda 支持的宏扩展 AWS CloudFormation 宏的理解 在cfn模板的创建过程中,我们会使用内置函数和伪函数对配置参数进行进一步处理,避免冗长的写法,更灵活的配…

西门子精彩触摸屏SMART V3组态报警的具体方法示例

西门子精彩触摸屏SMART V3组态报警的具体方法示例 用户自定义报警分为离散量报警和模拟量报警。 离散量报警:离散量对应于二进制数的1位,离散量的两种相反状态可以用1位二进制数的0、1状态来表示。例如:电动机的交流接触器的接通和断开、各种故障信号的出现和消失,都可以用…

建模助手:Revit中梁注释设置表达相对净高

一、Revit中梁注释设置表达相对净高 当我们利用 Revit 软件做管综的时候,需要明确与结构体的相对位置关系,下面我们就用“梁标记”的方式来做一下标记,在平面图上表达一下相对净高。如下图: 这样的平面梁标注是如何做上去的呢? 首…

获取网络时间、解析xml、截取string

很多游戏具有每日登陆奖励功能,为防止玩家修改本地时间,需要读取服务器时间。下面分两部分介绍获取网络时间的两种方法,第一部分解析xml,第二部分截取string。 第一部分:通过国家授时中心链接获得的数据如下: 获取网络…

互联网+医疗解决方案

国家“互联网”行动指导意见,明确“互联网医疗健康”行动路线。 制定“互联网”行动计划,推动移动互联网、云计算、大数据、物联网等与现代制造业结合,促进电子商务、工业互联网和互联网金融健康发展,引导互联网企业拓展国际市场…

麒麟信安携手河南IT联盟召开 《麒麟信安信创应用解决方案》线上分享会

在党政及金融、交通、能源等重要行业的信创应用步伐逐步加快的背景下,各行业均面临着不同程度的国产化落地难题。11月29日下午,麒麟信安与河南省信息协会IT产业分会(河南IT联盟)携手召开《麒麟信安信创应用解决方案》线上分享会&a…

微信小程序| 做一款可以计算亲戚关系的计算器

📌个人主页:个人主页 ​🧀 推荐专栏:小程序开发成神之路 --【这是一个为想要入门和进阶小程序开发专门开启的精品专栏!从个人到商业的全套开发教程,实打实的干货分享,确定不来看看? …

Spring(Spring的理解+DI+Spring的创建)

目录 1. Spring 是什么 2. DI 3. 面试题: IoC 和 DI 有什么区别? 4. Spring 的创建 5. 将 Bean (对象) 存储到 Spring (容器) 中 6. 将 Bean (对象) 从 Spring (容器) 中取出来 7. 面试题: ApplicationContext 和 BeanFactory的区别 8. getBean 更多用法 1. Spring 是…

能否在虚拟平台里构建真实的生活体验?

接近三年的疫情,重构了每一个人的生活。线下活动的频繁延期、取消,使得物理空间的聚集充满了不确定性,线上办公、网络授课等远程协同的方式在这样的时代背景下,毫无疑问成了主旋律。曾经只停留在想象层面的不出门就能完成工作、上…

u盘打不开常见原因|数据恢复方法|解决方案

u盘作为一种常用的外部存储器,能够帮助我们存放大量的数据,如图片、文档、视频等文件类型。但是在使用过程中,难免会遇到这样或那样的问题,比如使用过程中出现u盘打不开的情况,但是里面又有自己重要的文件,…

数字图像处理(入门篇)一 图像的数字化与表示

目录 1 人眼图像是如何形成的? 2 图像的感知与获取? 3 图像的数字化 4 数字图像的表示 1 人眼图像是如何形成的? 人眼近似为一个球体,物体的光线经过角膜和晶状体的折射,在视网膜上形成“倒立缩小”的实像。 视网膜…

这或许是全网最详细的介绍预言机赛道的视频课程,通俗易通,有趣有料!

图片来源:由无界版图 AI 绘画工具生成有一句话在创业者中很流行:Web3创业三大坑,隐私、跨链、预言机……搞塌加密市场的DK和SBF还在豪华度假酒店里思考人生搞隐私,一毛钱没赚到的Tornado cash开发者却在吃牢饭……加密圈前十大资产…

javascript中的polyfill是什么,polyfill和babel的关系

首先我们看看这个单词的意思 好像也没有解释啥,但是给人的感觉是一种用来补充,优化的东西。 没错在js中也正有这个意思 js中的polyfill用来表示,根据新特性的定义,创建一段与之行为等价,但是能够在旧的js环境中运行的…

如何实现机器人自动拉微信群

如果想长期运营一个微信群,每天手动拉人进群是很痛苦的事情。实际上可以用微信机器人来替代人力,实现过程也并没有想象中的那么困难 引导一下思路 1. 经验分析 如果是手动拉人进群的话,根据我们的日常经验,基本上逻辑是这样的&…