求树的直径算法以及证明

news/2024/4/20 8:39:37/文章来源:https://blog.csdn.net/qq_23096319/article/details/128096138

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

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

正确性证明:

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

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

根据算法操作(2),∣PQ∣≥∣PA∣,∣PQ∣≥∣PB∣|PQ|\geq|PA|,|PQ|\geq|PB|PQPA,PQPB,
减去公共部分得 ∣NQ∣≥∣NA∣,∣NQ∣≥∣NB∣|NQ|\geq|NA|,|NQ|\geq|NB|NQNA,NQNB,
容易得 ∣QM∣=∣NQ∣+∣MN∣>∣MA∣|QM|=|NQ|+|MN|>|MA|QM=NQ+MN>MA,
因此,∣BQ∣=∣BM∣+∣QM∣>∣BM∣+∣MA∣=∣AB∣|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→uw\rightarrow uwux→ux\rightarrow uxu有公共点,取w=vw=vw=v,而这与算法步骤中δ(u,v)\delta(u,v)δ(u,v)最大相矛盾。
在这里插入图片描述
根据第一点图①不存在,这和我证明的第(3)点对应,但我否定了图①情况后并没有进一步推证uvuvuvxyxyxy存在公共部分(不仅仅是我第(2)点提及只有一个交点)的情形。或者说我的证明分类讨论的对象是算法求解出的PQPQPQ和假设直径ABABAB之间的关系,遗漏了该情形。从∀u\forall uu出发讨论更容易分类。
在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【计算机】可信平台模块Trusted Platform Module - TPM

简述 Brief Introduction TPM内部功能模块示意图: 引述 Trusted Platform Module Technology Overview (Windows) | Microsoft Learn: Trusted Platform Module (TPM) technology is designed to provide hardware-based, security-related functions.…

「区块链+数字身份」:DID 身份认证的新战场

美国经济学家布莱恩 • 阿瑟在其著作《技术的本质》中,写过这么一句话:「技术总是进行着这样一种循环,为解决老问题去采用新技术,新技术又引发新问题,新问题的解决又要诉诸更新的技术」。 区块链技术之所以能流行&…

在MacOS上实现两个网络调试助手的UDP通信测试

文章目录一、背景二、网络调试助手软件三、UDP通信过程一、背景 因为有一个项目要中会使用本机中两个应用程序之间的UDP通信。 因此本文记录一下怎么在MacOS上实现两个网络调试助手的UDP通信测试。 二、网络调试助手软件 我使用的网络调试助手软件是:网络调试助…

Redis实战——优惠券秒杀(超卖问题)

1 实现优惠券秒杀功能 下单时需要判断两点:1.秒杀是否开始或者结束2.库存是否充足 所以,我们的业务逻辑如下 1. 通过优惠券id获取优惠券信息 2.判断秒杀是否开始,如果未返回错误信息 3.判断秒杀是否结束,如果已经结束返回错误…

传奇登录器打不开的四种原因

最近很多传奇玩家或者GM都遇到了传奇登陆器打不开,没反应,提示无法访问指定设备等问题,导致很多游戏没有办法玩,让玩家心情沮丧,作为GM,那么就更伤心了,很多玩家进不来游戏,开服数千…

Maven笔记(2022-11-29)

一、Maven简述 1.1 什么是Maven? Apache Maven 是一款基于 Java 平台的项目管理和构建工具,它基于项目对象模型(POM)的概念,通过一小段描述信息来管理项目的构建、报告和文档。 简单来讲Maven就是一个构建工具,用来管理我们的项目…

GMM算法

高斯混合模型聚类(Gaussian Mixture Mode,GMM) 高斯混合模型是一种概率式的聚类方法,它假定所有的数据样本x由k个混合多元高斯分布组合成的混合分布生成。 其中高斯分布的概率密度函数如下: 现在的问题就是如何求α,μ,σ\alpha,\mu,\sigm…

Spring-全面详解(学习总结---从入门到深化)

目录 Spring简介 Spring体系结构 IOC_控制反转思想 IOC_自定义对象容器 IOC_Spring实现IOC IOC_Spring容器类型 ​ 容器实现类 IOC_对象的创建方式 使用构造方法 使用工厂类的方法…

09【MyBatis多表关联查询】

文章目录三、MyBatis多表关联查询3.1 表的关系3.2 一对一查询3.2.1 搭建环境3.2.2 需求分析3.2.3 dao接口3.2.3 mapper.xml3.2.4 测试3.2.5 配置MyBatis一对一关系1)传统映射:2)使用association标签映射3.3 一对多查询3.3.1 需求分析3.3.2 da…

Kamiya丨Kamiya艾美捷大鼠微量白蛋白酶联免疫吸附试验说明书

Kamiya艾美捷大鼠微量白蛋白酶联免疫吸附试验预期用途: 大鼠微量白蛋白酶联免疫吸附试验(ELISA)是一种高灵敏度的双位点酶联免疫吸附试验(ELISA)大鼠生物样品中微量白蛋白的测定。仅供研究使用。 引言 白蛋白&#x…

SpringBoot、EasyPoi、Echarts 实现文档导入、出、图表显示 (饼状图、柱状图) 保姆级教程

一、介绍环境 EasyPOI: 现在我们就来介绍下EasyPoi,首先感谢EasyPoi 的开发者​。EasyPoi开源 easypoi 是为了让开发者快速的实现excel,word,pdf的导入导出,基于Apache poi基础上的一个工具包。easypoi教程 Echarts: …

转扩!寻找G2022次列车“旅客”

各位求职朋友大家好,欢迎乘坐G2022次列车 本次列车为6节编组,由上海开往北京,途径宁波、重庆 本次列车乘务组全体工作人员为您提供全方位福利待遇 上车地址:上海擎创信息技术有限公司 - 社会招聘 (eoitek.com) 如您还需其他帮助…

Java给图片增加水印,根据图片大小自适应,右下角/斜角/平铺

Hi,I’m Shendi 最近写自己的文件服务器,上传图片时需要自动增加水印,在这里记录一下 文章目录效果展示读取图片从 byte[] 读取图片获取画板绘制水印根据图片大小自适应水印大小右下角文字水印斜角水印平铺水印图片水印输出图片水印就是在图片…

SLAM学习笔记(二)

5.相机与图像 相机将三维世界中的坐标点(单位米)映射到二维图像平面(单位为像素)的过程中能够用一个几何模型进行描述。 单目相机(Mono)的成像过程: 1、世界坐标系下有个固定的点P,世界坐标为 2、由于相…

基于Java+SSM+Vue+ElementUi的汉语言类网上考试系统

项目介绍 21世纪的今天,随着社会的不断发展与进步,人们对于信息科学化的认识,已由低层次向高层次发展,由原来的感性认识向理性认识提高,管理工作的重要性已逐渐被人们所认识,科学化的管理,使信…

前置微小信号放大器在光声技术的血管识别研究中的应用

实验名称:前置微小信号放大器在光声技术的血管识别研究中的应用 研究方向:生物识别技术 测试目的: 利用MATLAB对光声血管进行识别:1、对光声血管图库的图像进行预处理包括归一化、二值化、平滑、细化和毛刺修剪得到细化图像&#…

【安卓逆向】去除云注入(使用MT论坛dl的方法总结拓展)

1 需求 因为最近使用的虚拟机突然不能用了,被人云注入强制弹窗,如下图:(这一看就是云注入了) 2 大佬的方法 如图(MT大佬分享的,感兴趣的朋友可以去大佬主页看看他其他文章)&…

蓝海创意云接受【看苏州】独家专访:助力苏州数字文化行业全方位发展

近日,由蓝海创意云提供渲染服务的动漫电影《老鹰抓小鸡》获金鸡奖最佳美术片提名,位列获奖名单的《长津湖》《独行月球》也由蓝海创意云渲染提供了后期服务。 就此,苏州广播电视总台旗下的苏州权威热点新闻和视频平台【看苏州】对蓝海彤翔执…

[附源码]计算机毕业设计springboot基于Java的失物招领平台

项目运行 环境配置: Jdk1.8 Tomcat7.0 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。 项目技术: SSM mybatis Maven Vue 等等组成,B/S模式 M…

用R Shiny生态快速搭建交互Web网页APP应用

什么是Shiny? Shiny包可以快速搭建基于R的交互网页应用。对于web的交互,之前已经有一些相关的包,不过都需要开发者熟悉网页编程语言(html,CSS,JS)。最近我们被客户要求撰写关于R Shiny的研究报告,包括一些…