求树的直径算法以及证明
以下为两次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| ∣PQ∣≥∣PA∣,∣PQ∣≥∣PB∣,
减去公共部分得 ∣ C Q ∣ ≥ ∣ C A ∣ , ∣ C Q ∣ ≥ ∣ C B ∣ |CQ|\geq|CA|,|CQ|\geq|CB| ∣CQ∣≥∣CA∣,∣CQ∣≥∣CB∣,
对于 ∣ A Q ∣ = ∣ A C ∣ + ∣ C Q ∣ ≥ ∣ A C ∣ + ∣ C B ∣ = ∣ A B ∣ |AQ|=|AC|+|CQ|\geq|AC|+|CB|=|AB| ∣AQ∣=∣AC∣+∣CQ∣≥∣AC∣+∣CB∣=∣AB∣,同理 ∣ B Q ∣ ≥ ∣ A B ∣ |BQ|\geq|AB| ∣BQ∣≥∣AB∣,
由于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| ∣PQ∣≥∣PA∣,∣PQ∣≥∣PB∣,
减去公共部分得 ∣ N Q ∣ ≥ ∣ N A ∣ , ∣ N Q ∣ ≥ ∣ N B ∣ |NQ|\geq|NA|,|NQ|\geq|NB| ∣NQ∣≥∣NA∣,∣NQ∣≥∣NB∣,
容易得 ∣ 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 w→u和 x → u x\rightarrow u x→u有公共点,取 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出发讨论更容易分类。
求树的直径算法以及证明相关推荐
- hdu 4607 Park Visit 求树的直径
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4607 Claire and her little friend, ykwd, are travelli ...
- 求树的直径的两种方法
树的直径 树型dp求树的直径 优缺点: 优点为可以处理边权为负的情况,但不易得到直径的路径(指树的直径经过什么点). 代码模板: #include<bits/stdc++.h> using ...
- 《鲁滨逊漂流记》题解(LCA算法求树的直径)
Description <鲁滨逊漂流记>只讲到了鲁滨逊在岛上建立起一个自给自足的生态环境.而大家不知道的是,在此之后,鲁滨逊因为太无聊,开始探索周边的岛屿,一共 NNN 天.鲁滨逊第 11 ...
- 求树的直径+并查集(bfs,dfs都可以)hdu4514
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4514 这题主要是叫我们求出树的直径,在求树的直径之前要先判断一下有没有环 树的直径指的就是一棵树上面距 ...
- 树的直径算法(dfs)
1.什么是树的直径? 树的直径是一颗树中任意两点最长的距离 2.如何求树的直径? (1).任意找一点x,并求得树上任意一点到x的距离存到数组dist中 (2).找到距离x最长的点y并以点y为起点找到树 ...
- 树上子链(树形dp求树的直径)
树上子链 题意: 给定一棵树 T ,树 T 上每个点都有一个权值. 定义一颗树的子链的大小为:这个子链上所有结点的权值和 . 请在树 T 中找出一条最大的子链并输出. 题解: 求树的直径,题目中存在负 ...
- HDU4612+Tarjan缩点+BFS求树的直径
tarjan+缩点+树的直径 题意:给出n个点和m条边的图,存在重边,问加一条边以后,剩下的桥的数量最少为多少. 先tarjan缩点,再在这棵树上求直径.加的边即是连接这条直径的两端. 1 /* 2 ...
- Problem K. Road Network - ACPC2015(求树的直径 dp)
Problem K. Road Network 题目链接 Arab Collegiate Programming Contest 2015 题意: 树形的公路,如果阻塞道路可以断开两个区域彼此的连接, ...
- 求树的直径(两种方法)
① 两次dfs 方法:先从任意一点P出发,找离它最远的点Q,再从点Q出发,找离它最远的点W,W到Q的距离就是是的直径 证明如下: ①若P已经在直径上,根据树的直径的定义可知Q也在直径上且为直径的一个端 ...
最新文章
- 使用apache的activemq集合JMS处理异步消息
- Windows下Rtools环境安装
- ActiveX(五)更好的“ActiveX”?
- sql like N'%%',N 是代表什么意思 及Like语句详解
- 动态创建表格给同一个标签创建点击事件并让点击事件操作内容不一样
- 会计期间13-16怎么用
- hashmap为什么线程不安全_面试官:你说 HashMap 线程不安全,它为啥不安全呢?...
- 2015年12月16日 Oracle语句实现有则更新无则插入
- python运行不了程序代码_Python源码分析2 - 一个简单的Python程序的执行
- C语言链表与malloc函数
- Flutter实战之Dio入门使用
- HTML+CSS——网页设计项目完整版本(阿里矢量图标库)分享
- 谈谈你怎么理解产品经理
- android 监听软键盘在页面的展开和隐藏
- avod论文理解与代码解读
- 大数据框架之Spark详解
- idea 懒人神器 保存自动格式化 Save Action插件
- jsch session(ssh)
- python爬虫个人文档整理
- 理想职业计算机程序英语作文,理想职业英语作文(通用5篇)