当前位置: 首页 > news >正文

三、树和割集

文章目录

  • 1、树
    • 1.1 树的定义
    • 1.2 树的性质
    • 1.3 极小连通图
    • 1.4 树的中心
    • 1.5 生成树
      • 1.5.1 最小生成树
  • 2、 割点和桥
  • THE END

1、树

1.1 树的定义

\qquad 定义: 一个连通的无圈的图称为树。
\qquad 只有一个顶点的树叫做平凡树
\qquad 树中度为1的节点称为叶子结点
\qquad 推论1: 非平凡树中至少有两个叶子结点。
\qquad 推论2: 树是双图。
\qquad 定义: 一个无圈的图称为森林。

1.2 树的性质

\qquad 定理1: G = ( V , E ) G=(V, E) G=(V,E)是一个 ( p , q ) (p,q) (p,q)图,则下列命题是等价的:

  • G G G是树
  • G G G中任意两个顶点之间有唯一的一条路
  • G G G是连通的,且 p = q + 1 p=q+1 p=q+1
  • G G G中无圈,且 p = q + 1 p=q+1 p=q+1
  • G G G中无圈, G G G中任意两个不相邻的顶点之间加一条边,则得到一个有唯一圈的图
    \qquad 要证明上述定理成立,需要证明任意两个结论之间互为充分必要条件,则可以将5条结论围成一圈,依次证明前一条结论是后一条结论的充要条件即可。在证明第二条到第三条的结论时,可以使用数学归纳法进行证明。证明第三条到第四条结论,从第四条结论到第一条结论和从第五条结论到第一条结论时,可以使用反证法进行证明。

1.3 极小连通图

\qquad 定义: 去掉一条边就不连通的连通图叫做极小连通图。
\qquad 定理: G G G是树的充要条件为 G G G是极小连通图。

1.4 树的中心

\qquad 偏心率: 给定一个树 G = ( V , E ) G=(V,E) G=(V,E),和任意一个 v ∈ V v \in V vV,定义节点 v v v的偏心率为 e ( v ) = m a x u ∈ V { d ( u , v ) } e(v)=max_{u \in V}\{d(u,v)\} e(v)=maxuV{d(u,v)}
\qquad 树的半径: 树中所有顶点的最小偏心率为树的半径, r ( G ) = m i n v ∈ V { e ( v ) } r(G)=min_{v \in V}\{e(v)\} r(G)=minvV{e(v)}
\qquad 树的中心: 树的中心表示为一个节点集合 H = { v ∣ v ∈ V , e ( v ) = r ( v ) } H=\{v|v \in V, e(v)=r(v)\} H={vvV,e(v)=r(v)}

1.5 生成树

\qquad 给定一个图 G = ( V , E ) G=(V,E) G=(V,E), 若 G G G的一个生成子图是树,则称其为 G G G生成树
\qquad G = ( V , E ) G=(V,E) G=(V,E)生成树存在的充要条件 G G G是连通图。
\qquad 给定一个图 G = ( V , E ) G=(V,E) G=(V,E)是一个 ( p , q ) (p,q) (p,q)图, G G G中至多有 p p − 2 p^{p-2} pp2个生成树(上界)。

1.5.1 最小生成树

\qquad 对于一个图 G = ( V , E ) G=(V,E) G=(V,E)中所有的生成树,其中权值最小的生成树叫做最小生成树,求最小生成树的两个算法如下:
\qquad Prime 算法随机从图中选择一个顶点加入到最小生成树树集合中,之后选择和最小生成树集合中已经存在的顶点相邻接的其他顶点中边权值最下的顶点添加到最小生成树集合中(在此过程中判断是否有圈存在,排除生成圈的顶点),直到所有的顶点都检查完毕,其算法复杂度为 O ( p 2 ) O(p^2) O(p2)
\qquad Kryscal 算法: 将图中所有的边按照权值进行从小到大排序,依次向生成树集合中添加权值最小的边,每添加一条边需要判断是否有圈产生,跳过有圈生成的边,直到所有的边均检查完毕为止,算法复杂度为 O ( q ∗ l o g q ) O(q*log\ q) O(qlog q)

2、 割点和桥

\qquad 割点定义: 给定一个图 G = ( V , E ) G=(V,E) G=(V,E) v ∈ V v \in V vV,假如 G − v G-v Gv的分支数大于 G G G的分支数,则称 v v v G G G的一个割点。
\qquad 每一个非平凡的图中至少有两个顶点不是割点(从最长路来证明)。哈密顿图中一定没有割点,从哈密顿图的定义来证明,哈密顿图中一定有哈密顿回路。
\qquad 定理1(割点的特征性质): 给定一个图 G = ( V , E ) G=(V,E) G=(V,E) v ∈ V v \in V vV,则下述命题等价:

  • v v v是割点
  • ∃ u , v ∈ V , u ≠ w \exist u, v \in V, u \neq w u,vV,u=w, u u u v v v之间的所有的路均通过 v v v.
  • ∃ V / { v } \exist V /\ \{v\} V/ {v}的一个划分 { U , W } \{U, W\} {U,W},使得 ∀ u ∈ U , ∀ v ∈ V \forall u \in U, \forall v \in V uU,vV u , v u, v u,v之间的路均通过 v v v

\qquad 桥定义: 给定一个图 G = ( V , E ) G=(V,E) G=(V,E) x ∈ E x \in E xE,假如 G − x G-x Gx的分支数大于 G G G的分支数,则称 x x x G G G的一个桥。
\qquad 定理1(桥的特征性质): 给定一个图 G = ( V , E ) G=(V,E) G=(V,E) x ∈ E x \in E xE,则下述命题等价:

  • x x x是桥
  • ∃ u , v ∈ V , u ≠ w \exist u, v \in V, u \neq w u,vV,u=w, u u u v v v之间的所有的路均通过 x x x.
  • ∃ E / { x } \exist E /\ \{x\} E/ {x}的一个划分 { U , W } \{U, W\} {U,W},使得 ∀ u ∈ U , ∀ v ∈ V \forall u \in U, \forall v \in V uU,vV u , v u, v u,v之间的路均通过 x x x
  • x x x不在任何圈上

THE END

相关文章:

三、树和割集

文章目录 1、树1.1 树的定义1.2 树的性质1.3 极小连通图1.4 树的中心1.5 生成树1.5.1 最小生成树 2、 割点和桥THE END 1、树 1.1 树的定义 \qquad 定义: 一个连通的无圈的图称为树。 \qquad 只有一个顶点的树叫做平凡树。 \qquad 树中度为1的节点称为叶子结点。…...

泛型中<>和()中的类型

尖括号 < > 中的类型参数定义了一组可以被替换的类型占位符&#xff0c;而圆括号 (...) 内的类型使用则是这些类型参数的具体应用场景&#xff0c;展示了这些类型变量如何参与到函数的参数和返回值类型定义中去。这样设计既保证了代码的灵活性&#xff0c;又保持了类型安…...

spark mllib 特征学习笔记 (一)

PySpark MLlib 特征处理详解 PySpark MLlib 提供了丰富的特征处理工具&#xff0c;帮助我们进行特征提取、转换和选择。以下是 PySpark MLlib 中常用的特征处理类及其简要介绍。 1. Binarizer Binarizer 是将连续特征二值化的转换器。 from pyspark.ml.feature import Bina…...

SQLite 日期 时间

SQLite 日期 & 时间 SQLite 是一种轻量级的数据库管理系统&#xff0c;广泛用于各种应用程序中。它支持标准的 SQL 语法&#xff0c;包括对日期和时间的处理。在 SQLite 中&#xff0c;日期和时间可以通过几种不同的方式来存储和操作。 日期和时间数据类型 SQLite 使用 …...

飞书API 2-1:如何通过 API 创建文件夹?

本文探讨如何通过飞书的 API 来创建文件夹。通过 API 创建的文件夹&#xff0c;一般是放在共享空间&#xff0c;如果要放在个人空间&#xff0c;建议手动创建。 查看 API 文档 API 路径&#xff0c;可在飞书开放平台的服务端 API&#xff0c;依次查找云文档>云空间>文件…...

【APP移动端自动化测试】第一节.环境配置和adb调试工具

文章目录 前言一、Java环境搭建二、AndroidSDK环境搭建三、Android模拟器安装四、adb调试工具基本介绍 4.1 adb构成和基本原理 4.2 adb获取包名&#xff0c;界面名 4.3 adb文件传输 4.4 adb获取app启动时间 4.5 adb获取手机日志 4.6 adb其他有关…...

Kotlin 协程:从基础概念到开发实践

前言 上一篇文章 深入理解Android多线程开发:场景应用与解决方案解析 针对Android开发中的多线程应用场景和相应的解决方案做了一个梳理。 总结出了Android开发中多线程编程的几个重要点: 资源复用和优化切线程任务编排并结合示例说明了Kotlin协程在处理上述问题时的优势。 …...

IPNV6

特征——升级点&#xff1a; 1、全球单播地址 ----IPV4地址下的公有地址 V6下没 nat 2、可聚合性 (IANA组织对全球的地址进行合理分配) 3、多宿主——一个物理接口可以同时拥有多个不同网段的IPV6地址&#xff1b;但不同接口不能在同一网段 4、自动配置 1&#xff…...

C++并发之锁(std::lock_guard,std::unique_lock)

目录 1 概述2 使用实例3 接口使用3.1 lock_guard3.2 adopt_lock3.3 defer_lock3.4 try_to_lock3.5 try_lock3.6 release3.7 lock3.8 call_one1 概述 锁保护是通过使互斥对象始终处于锁定状态来管理互斥对象的对象。。   在构造时,互斥对象被调用线程锁定,在析构时,互斥被解…...

FreeRTOS队列(queue)

队列(queue)可以用于"任务到任务"、 "任务到中断"、 "中断到任务"直接传输信息。 1、队列的特性 1、1常规操作 队列的简化操如下图所示&#xff0c;从此图可知&#xff1a; 队列中可以包含若干数据&#xff1a;队列中有若干项&#xff0c;这…...

Azure数据分析Power BI

Azure数据分析Power BI 一、Power BI简介二、Power BI 如何匹配角色三、Power BI 构建基块四、使用 Power BI 服务一、Power BI简介 Microsoft Power BI 是一系列的软件服务、应用和连接器,这些软件服务、应用和连接器协同工作,将不相关的数据源转化为合乎逻辑、视觉上逼真的…...

将 Python3 程序打包成 APK 并运行在 ARM 的 Android 系统中

作为一个开发者&#xff0c;我们经常需要将我们的 Python 程序部署到移动端&#xff0c;以便更好地服务于用户。然而&#xff0c;直接在 Android 系统上运行 Python 程序却存在一定的挑战&#xff0c;因为 Android 系统默认不支持 Python。这篇文章将介绍如何将 Python3 程序打…...

学习记录:VS2019+OpenCV3.4.1实现SURF库函数的调用

最近在学习opencv的使用&#xff0c;在参照书籍《OpenCV3编程入门》实现SURF时遇到不少问题&#xff0c;下面做归纳总结。 错误 LNK2019 无法解析的外部符号 “public: static struct cv::Ptr __cdecl cv::xfeatures2d::SURF::create(double,int,int,bool,bool)” (?createSUR…...

JVM-基础知识

JVM-基础知识 什么是JVM JVM是一种跨语言的平台&#xff0c;任何语言只要能编译成.class文件都可以被JVM运行。JVM只和.class文件有关系&#xff0c;和Java语言没关系。JVM是一种虚拟机规范。 java文件是如何交给JVM执行的 JVM的常见实现 HostStop:Oracle官方另外还有IBM的J9、…...

保密工作应党而生、伴党而行、为党而兴

1.&#xff08;C &#xff09;工作应党而生、伴党而行、为党而兴&#xff0c;始终是党和国家的一项重要工作。 A. 农业 B. 国防 C. 保密 D. 文化 2.机关、单位对所产生的国家秘密事项&#xff0c;应当按照国家秘密及其密级的具体范围的规定确定密级&#xff0c;同时确定&#x…...

docker login 报错: http: server gave HTTP response to HTTPS client

环境&#xff1a; 自建 Harbor、Docker 1. 问题分析 # 命令&#xff0c;这里用的是 IP&#xff0c;可以为域名 docker login -u test 172.16.51.182:31120 # 输入密码 Password:# 报错如下&#xff1a; Error response from daemon: Get "https://172.16.51.182:31120/…...

「C系列」C 文件读写

文章目录 一、C 文件读写1. 打开文件2. 写入文件3. 读取文件4. 关闭文件5. 文件读写模式6. 错误处理 二、常见问题1. 文件打开失败2. 文件读写错误3. 文件读写位置4. 缓冲区刷新 三、相关链接 一、C 文件读写 在C语言中&#xff0c;文件读写是通过一系列的标准库函数来完成的&…...

编程中的cos:深度解析与应用探索

编程中的cos&#xff1a;深度解析与应用探索 在编程的广阔天地中&#xff0c;cos这一数学概念扮演着举足轻重的角色。它不仅是数学函数库中的基础元素&#xff0c;更是图形渲染、科学计算以及数据处理等多个领域的核心工具。本文将从四个方面、五个方面、六个方面和七个方面&a…...

计算机毕业设计hadoop+spark+hive知识图谱酒店推荐系统 酒店数据分析可视化大屏 酒店爬虫 高德地图API 酒店预测系统 大数据毕业设计

流程&#xff1a; 1.Python爬取去哪儿网全站旅游数据约10万&#xff0c;存入mysql; 2.使用pandasnumpy/hadoopmapreduce对mysql中旅游数据进行数据清洗&#xff0c;使用高德API计算地理信息&#xff0c;最终转为.csv文件上传hdfs; 3.hive建库建表导入.csv文件作为数据集&#x…...

简单谈谈云服务器私网IP的存在意义及优势

云服务器是基于虚拟化技术的计算资源&#xff0c;可以在云平台上灵活创建和管理。为了满足不同用户的需求&#xff0c;云服务提供商在云服务器上分配了两种类型的IP地址&#xff1a;公网IP和私网IP。其中&#xff0c;私网IP是指在局域网内使用的内部IP地址&#xff0c;无法通过…...

python错题(2)

、...

禁止methtype联网

mathtype断网_如何禁止mathtype联网-CSDN博客https://blog.csdn.net/qq_41060221/article/details/128144783...

【iOS】UI学习——cell的复用及自定义cell

目录 前言cell的复用手动&#xff08;非注册&#xff09;自动&#xff08;注册&#xff09; 自定义cell总结 前言 Cell复用和自定义Cell是在开发iOS应用时常见的一种优化技巧和定制需求。   Cell复用是UITableView或UICollectionView的一个重要优化机制。当用户滚动这些视图时…...

【详细介绍下PostgreSQL】

&#x1f308;个人主页: 程序员不想敲代码啊 &#x1f3c6;CSDN优质创作者&#xff0c;CSDN实力新星&#xff0c;CSDN博客专家 &#x1f44d;点赞⭐评论⭐收藏 &#x1f91d;希望本文对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出指正&#xff0c;让我们共…...

基于Matlab停车场车牌识别计时计费管理系统 【W2】

简介 停车场车牌识别计时计费管理系统在现代城市管理中具有重要意义。随着城市化进程的加快和车辆数量的增加&#xff0c;传统的人工管理停车场的方式已经难以满足效率和精确度的要求。因此引入车牌识别技术的自动化管理系统成为一种趋势和解决方案。 背景意义 提升管理效率&a…...

码住!详解时序数据库不同分类与性能对比

加速发展中的时序数据库&#xff0c;基于不同架构&#xff0c;最流行的类别是&#xff1f; 作为管理工业场景时序数据的新兴数据库品类&#xff0c;时序数据库凭借着对海量时序数据的高效存储、高可扩展性、时序分析计算等特性&#xff0c;一跃成为物联网时代工业领域颇受欢迎的…...

【C/C++】实参与形参的区别

在编程中&#xff0c;形参&#xff08;形式参数&#xff09;和实参&#xff08;实际参数&#xff09;是函数调用中的两个基本概念&#xff0c;它们在函数定义和函数调用中扮演着不同的角色。 形参&#xff08;Formal Parameters&#xff09;&#xff1a; 形参是在函数定义时声明…...

---异常---

我们在运行程序时总遇到各种与报错&#xff0c;数组越界&#xff0c;空指针的引用&#xff0c;这些在java中都称为异常 对于不同的错误都具有一个与他对应的异常类来秒描述 这是对于数组越界这个类里有的方法&#xff0c;这些是描述异常的 在java中有一个完整的描述异常的类的…...

python如何终止程序运行

方法1&#xff1a;采用sys.exit(0)&#xff0c;正常终止程序&#xff0c;从图中可以看到&#xff0c;程序终止后shell运行不受影响。 方法2&#xff1a;采用os._exit(0)关闭整个shell&#xff0c;从图中看到&#xff0c;调用sys._exit(0)后整个shell都重启了&#xff08;RESTAR…...

网络:用2个IP地址描述一个连接

用2个IP地址描述一个连接。这是在阅读了《TCP/IP指南》后的感想&#xff0c;与工业标准不同&#xff0c;需注意区分。 如果一个IP地址有48位&#xff0c;则用96位描述一个连接 对于单播&#xff0c;是每个IP分别描述位置。位置包括&#xff1a;邮局编号主机编号&#xff0c;采用…...

泉州模板做网站/教育培训机构排名

面试跳槽 说到面试跳槽&#xff0c;大家从当初入行开始就一直摆脱不开它&#xff08;咱们就是通过不断跳槽才能更快地提升自己&#xff09;。在我们的技术生涯中会有很多大大小小的面试&#xff0c;对我们程序员来说每一次面试都是一次提升的机会&#xff0c;不管是简历修改&a…...

html 企业网站模板/在线网站流量查询

有没有遇到过&#xff0c;导航UITableView&#xff0c;在push&#xff0c;back回来之后&#xff0c;当前cell仍然是选中的状态。当然&#xff0c;解决办法简单&#xff0c;添加一句[tableView deselectRowAtIndexPath:indexPath animated:YES]即可。令人纠结的时&#xff0c;在…...

杭州做网站五/seo网站优化培训怎么样

冒泡排序 通过相邻元素的比较和交换&#xff0c;使得每一趟循环都能找到未有序数组的最大值或最小值。 // 最好&#xff1a;O(n)&#xff0c;只需要冒泡一次数组就有序了。 // 最坏&#xff1a;O(n) // 平均&#xff1a;O(n) function bubbleSort(arr){for(let i 0,len arr.l…...

网站做好了怎么做后台/独立站

最近在整理之前工作的文件&#xff0c;发现大概有50个小时的专家call & 会议录音啥的&#xff0c;于是就研究了一下如何批量把长语音转成格式优美的文字文档。 当然做事情之前先来知乎搜了搜有没有现成的解决方案可用&#xff0c;于是发现了这个问题&#xff0c;但一楼说的…...

厦门外贸网站建设多少钱/百度如何做推广

arpspoof是一个好用的ARP欺骗工具&#xff0c;Kali linux中自带了该工具&#xff0c;在ubuntu中&#xff0c;安装它只需运行命令&#xff1a;sudo apt-get install dsniff安装完成后&#xff0c;输入命令&#xff1a;man arpspoof 可以查看使用手册&#xff0c;2.4版本的手册内…...

湖南做网站公司/seo教学网站

要想在地址栏隐藏url传递的参数&#xff0c;不能直接隐藏,但有几下几个变通的方法. 使用类似Base64编码,将URL参数进行简单加密. 使用框架页; 使用POST方式传递数据; 使用Cookie传递数据; 下面主要介绍模拟表单提交的post方式&#xff1a; function post(URL, PARAMS) {var tem…...