离散数学--图论

news2024/11/24 13:34:32

目录

1.简单概念

2.握手定理

3.点割集

4.边割集

5.点连通度和边连通度

6.Dijstra算法&&最短路径

7.有向图的连通性

8.图的矩阵表示

9.欧拉图问题

10.哈密尔顿图


1.简单概念

(1)这个里面的完全图比较重要,完全图是例如k3,k5这样的表示方法,角标表示的就是图上面的节点的个数;

(2)完全图定义是这个图上面的任何一个节点和其他的节点之间都有连接,但是这个节点自己没有形成环,在矩阵的表示上面矩阵对角线上面的元素是0,其他的元素都是1,这个0表示的就是节点自己没有形成环,1表示的就是节点和其他节点之间有一条连接边;

(3)图的同构:充要条件就是节点和边之间存在一一对应的关系,但是这个充要条件我们一般不是使用,因为这个充要条件还是无法进行判断两个图之间是否是同构的;

(4)在判断图的同构问题上面,我们使用的就是这个必要条件,就是两个图的节点的数量是相同的,边数也是相同的,度数相等的节点的数量也是相同的,因此我们在考试时候进行判断时,只需要这个判断节点数量和边的数量是否一样,一样的话看看读书相同的节点的数量是否是一样的,例如两个图1和2,图1和图2的节点数和边数都一样,我们就看看度数相同的节点的个数,如果图1和图2都是有3个5度的节点和2个3度的节点,这两个图就是同构的;

但是如果图1有一个3度的节点,但是图2的节点都是2度的,说明对于3度的节点而言,两个图的节点个数不相同,一个是1个,还有一个是0个,这个就不满足必要条件,这个时候的图1和图2就是不同构的;

2.握手定理

(1)节点的度数的和是这个图的边数的2被,例如这个图16个节点,我们就可以推断出来这个这个图有8条边;

(2)这个推论是经过证明的,所以我们可以直接进行使用,这个推论就是主要用来判断一串度数序列是否可以构成无向图 ,这个要求解释奇数度节点个数是偶数个;

大概就是说这个,例如1 3 5 7 6这个序列,是否可以构成无向图,奇数度节点个数就是1 3 5 7这四个节点,上面的1 3 5 7表示的是节点的度,表示这个图有5个节点,这五个节点的度分别是1 3 5 7 6,因为这里的奇数度结点个数是4,是偶数个,所以这个序列就可以构成这个无向图;

但是像1 3 9 6这样的序列,技术度节点只有3个,所以这个序列就无法构成无向图,所以我们通过这个握手定理的推论是可以进行一些直观的判断的;

3.点割集

(1)点割集实际上就是一个集合,里面可以有多个元素;

(2)简单的理解就是对于一个具有连通性的图,删除掉某个节点或者某些节点之后这个图就不联通,我们称这个节点或者这些节点就是点割集;

(3)示例图片的图割掉v3之后就不联通,所以v3就是一个点割集,割掉v5之后也不联通,v5也是一个点割集;

需要注意的就是这个割掉某个点之后,和这个节点相连的所有的边就会消失,割掉v2和v4之后,这个图就不会联通了,所以这个v2,v4在一起的这个集合就是点割集;

但是如果仅仅割掉v2或者v4可以发现这个图依然是联通的,这个时候我们就可以说单独的v2或者v4这个集合就不是点割集,只有v2,v4在一起的这个集合才是一个点割集;

4.边割集

(1)这个边割集和点割集都一样,就是一个普通的集合,删除这个集合里面的元素之后这个图就不再联通了;

(2)点割集和边割集的不同点就在于这个点割集删去的是点,边割集删去的是边,其他的规则就本上都是一样的;

(3)在数学符号语言里面,通常使用的是 V大写代表的是点(Vertex),使用大写的E代表边(Edge)这个为了记住这个表示方法,我们可以使用英文单词进行辅助记忆;

5.点连通度和边连通度

(1)删除某个或某些节点之后就不在连通的点,我们称之为点割集,这个过程中,可能在某些图里面,我们删除一个点就可以让这个图不再连通,可能我们要删除2个3个或者更多的点才能让这个图不再具有连通性;

这个多种途径里面,我们把这个删除最少的点就可以破坏连通性的点的个数称之为点连通度;点连通度使用K进行表示;

(2)一些推论

非连通图,因为这个图本来就不是连通的 ,所以我们规定非连通图的点连通度是0;

完全图的点连通度是n-1,n表示的就是这个完全图里面的节点的个数;

存在割点的图的点连通度是1,因为我们只要删去这个割点就可以破坏这个图的连通性;

(3)边连通度的定义和推论,类似于点连通度,边连通度使用λ进行表示;

(4)图的最小度表示的就是这个图的所有节点的度里面最小值,最小度是使用德塔(输入法无法敲打);

一般这个点连通度和边连通度和这个最小度 之间的关系就是点连通度<=边连通度<=最小度;

6.Dijstra算法&&最短路径

(1)这个图论的算法在许多的领域里面都是有这个应用的,在这个离散数学里面学习的图论,我们在计算机的核心课程数据结构里面的图也是大同小异的,包括这个算法迪杰斯特拉算法在这个数学建模的比赛里面也是经常使用的,所以我们在这里是有必要介绍一下的;

(2) 这个算法的本质就是这个贪心算法,简单的讲就是只会顾及眼前的利益,而不会去管这个后面的结果,在这个常规的算法介绍里面,通常都是这个使用两个集合来不断的更新(这个就是我第一次学习的时候看网上的博主讲的),但是这个我感觉很难理解,下面介绍一种新的方式(这个方式是从数学建模的角度);

(3)单源最短路径的子路径都是这个最短路径,我们这个实例是使用的1到3的最短路径,到底应该如何理解这个迪杰斯特拉算法呢?我们首先选取这个1节点作为源节点,1可以直接到达的节点就是2,5节点,到其他节点都是无法直接到达的,所以我们记作无穷大,12距离就是10,15距离就是5,然后我们找出这个里面的最短路径,就是1---5的5这个距离,然后在这个左边画上一个小图,表示1------5的情况;

(4)接下来,我们以15作为这个新的起始区域,相当于是把这个15看作为一个整体,把他们捆绑在了一起,这个整体可以直接到达的节点就是243节点,152长度是8,153长度是14,154长度是7,这个里面最短的就是7了,再把这个新的路径进行更新,补充在右边的这个小图上面;

(5)接下来就是把这个154捆绑在一起,作为一个新的整体,这个时候就出现了初学者们肯能会不理解的问题,就是在这个里面,154整体可以直接到达的就是23了,到达2的话,就是这个152,路径的长度就是8,到达3的话,就是这个153或者是1543这两条路径分别是14,13,总上来看最短路径长度就是8,这个时候我们就会添加上2这个节点;

(6)接下来就是把这个1542作为一个新的整体,然后找到这个整体到达3这个节点的最短距离,通过比较我们就可以发现这个1523就是这个最短的路径距离,我们就结束了这个整个的查找的过程,这个时候我们想要的1到3的最短路径就已经呼之欲出了,我们不仅找到了13之间的最短路径,这个路径上面的任意的子路径都是最短路径;

7.有向图的连通性

(1)这个里面我们会分别介绍一下这个强连通图,单向连通图,弱连通图这三种类型的图;

(2)这个强连通的意思就是这个图上面的任意的两个节点之间都是可以双向奔赴的,就是我有办法沿着有向的路径找到你 ,你有办法沿着有向的路径找到我,这个就是强连通性;

(3)单向连通实际上就是一个简单的中间状态,要求可能没有那么的苛刻,就是对于一个图里面的任意的两个节点,只要我们两个之间可以单向的找到就可以了,例如中间的这个图里面的13节点,1可以找到3,但是3没有办法找到1,1可以找到4,但是4没有办法找到1,5可以找到3,但是3可以找到5(这样肯定就会更好了),因为我们的要求是只要有一种方式找到对方,就满足这个单向连通的定义了,这个两个双向奔赴的情况肯定是单连通的,这样的图就属于单向的连通关系;

(4)弱连通就是,以上面的右边的图片为例,对于1这个节点,任何节点想要到达他都是不可能能的,因为这个节点只有初度,没有入度,这样的图就是这个弱连通图,其实判断弱连通图我们就可以观察这个图上面是不是有某个节点只有初度没有入度(1节点),或者只有入度但是没有初度(2节点),但是去掉方向之后这个图依然是连通的,这个时候我们就可以说这个图就是一个弱连通图

(5)通过上面的阐述相信你也发现了,强连通图一定是这个单向的连通图,单向的连通图一定是弱连通图;

8.图的矩阵表示

(1)邻接矩阵

就是两个节点之间如果有联系就是用n(n表示的就是这个路径的个数)进行标记,否则用0进行标记;

(2)邻接矩阵运用

这个定理是很重要的,首先我们看一下这个第一条,讲的就是这个路的个数,实际上就是通路的个数,在下面的图里面,画出了对应的邻接矩阵,12节点之间有2条路径 ,所以这个第一行第二列的矩阵元素就是2;

为了方便观察这个邻接矩阵,我们可以在这个矩阵的外面加上这个1234,分别表示的就是这个图上面的4个节点,这样我们就可以直观的看到每个矩阵元素表示的意义;

实际上面涉及到的路和回路,都涉及到矩阵的乘法,我们下面是以一个矩阵的4次方作为例子,这个新的矩阵里面,我们可以得到哪些有用的信息?

对角线元素除外,任何一个位置的矩阵元素表示的就是这个节点之间通路个数,这个矩阵肯定还是4行4列,因为这个矩阵本来就是一个方阵,24(表示2行4列)这个位置矩阵元素假设计算完之后就是5,那么这个就表示这个24节点之间的长度为4的通路数有5条;

对角线上面的元素,例如22(表示两行两列),假设这个位置的数据就是8,表示2这个节点回路数量就是8条;

题目一般是让你求两个节点之间的这个回路或者通路长度是n的数量,我们根据这个题目的要求确定要对于这个邻接矩阵进行几次方的操作。

9.欧拉图问题

(1)欧拉图问题的起源就是这个著名的哥尼斯堡七桥问题,当时就是有很多的人去求借这个问题,最后欧拉证明这个问题没有正确的答案,可见有的时候证明一个问题的解的存在性比求解这个问题本身更加重要;

(2) 下面就是欧拉图的一些基本的概念,例如这个欧拉路,欧拉回路,欧拉图,半欧拉图,单向欧拉路,其实看似这个概念很多,其实理解起来并不是很困难;

欧拉路就是存在一条路经过所有的边,成为欧拉路,每条边只可以经过一次,这样的我们就称之为欧拉路(对于无向图而言的);如果是有向图满足这样的条件,我们就可以称之为这个单向的欧拉路,如果这个过程中最后又可以回到原点,我们就称之为这个欧拉回路;

具有欧拉回路的图我们就称之为欧拉图,具有欧拉路但是没有回路的图叫做半欧拉图;

(3)无向图里面有一条欧拉路,当且仅当这个G是联通的,有0个或者2个奇数度的节点;(平凡图就是只有一个节点的图,平凡图是一定满足这个定理的)

(4)欧拉图&半欧拉图判定定理(无向图)

欧拉图要求这个图是连通的而且是没有奇度数顶点;

半欧拉图要求这个图是连通的而且这个图里面拥有2个奇度数顶点; 

(5)欧拉图&半欧拉图判定定理(有向图)

有向图是欧拉图要求每个顶点的入度等于初度,

是半欧拉图要求这个恰好有两个奇度数顶点,一个是入度比初度大1,一个是初度比入度大1,其他的顶点的入度都等于初度;

10.哈密尔顿图

(1)哈密尔顿图的定义:其实和欧拉图很像,但是不完全一样,因为这个说的是一次性经过所有的顶点,欧拉图说的是一次性经过所有的边,两者是有差别的;

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

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

相关文章

xcode配置快速打开终端命令行工具教程

以往我们使用idea编辑器或者vscode编辑器的时候&#xff0c;我们可以快速的在编辑器下面打开终端进行相关的操作&#xff0c;但是在xcode里面却没有这么方便的功能按钮&#xff0c;真的不是很习惯&#xff0c;所以这次就来给xcode配置这么一个方便的功能。 idea的Terminal 这…

AHPPEBot:基于表型和姿态估计的自主番茄采摘机器人

论文&#xff1a;AHPPEBot: Autonomous Robot for Tomato Harvesting based on Phenotyping and Pose Estimation 作者&#xff1a;Xingxu Li, Nan Ma, Yiheng Han, Shun Yang, Siyi Zheng 收录&#xff1a;ICRA2024 编辑&#xff1a;东岸因为一点人工一点智能 AHPPEBot&am…

NLP(16)--生成式任务

前言 仅记录学习过程&#xff0c;有问题欢迎讨论 输入输出均为不定长序列&#xff08;seq2seq&#xff09;自回归语言模型&#xff1a; x 为 str[start : end ]; y为 [start1 : end 1] 同时训练多个字&#xff0c;逐字计算交叉熵 encode-decode结构&#xff1a; Encoder将输…

v-cloak 用于在 Vue 实例渲染完成之前隐藏绑定的元素

如果你是后端开发者&#xff08;php&#xff09;&#xff0c;在接触一些vue2开发的后台时&#xff0c;会发现有这段代码&#xff1a; # CDN <script src"https://cdn.jsdelivr.net/npm/vue2/dist/vue.js"></script> # 或 <script src"https://cd…

bclinux基于欧拉(BigCloud Enterprise Linux For Euler)下安装mysql5.7

第一步&#xff1a;下载mysql5.7的rpm安装包 下载地址&#xff1a;https://dev.mysql.com/downloads/mysql/ 第二步&#xff1a;上传mysql安装包到Centos7的下 第三步&#xff1a;检查是否已经安装了mysql或者mariadb&#xff08;centos7默认安装&#xff09;&#xff0c;如已…

《intel开发手册卷3》读书笔记2

IA-32架构的内存管理分为两个部分&#xff1a;分段和分页。分段提供了一种隔离每个进程 或者任务代码、数据和栈模块的机制,保证多个进程或者任务能够在同一个处理器上运 行而不会互相干扰。分页机制实现了传统请求调页的虚拟内存系统&#xff0c;在这种系统中&#xff0c; 程序…

Python 机器学习 基础 之 数据表示与特征工程 【分箱、离散化、线性模型与树 / 交互特征与多项式特征】的简单说明

Python 机器学习 基础 之 数据表示与特征工程 【分箱、离散化、线性模型与树 / 交互特征与多项式特征】的简单说明 目录 Python 机器学习 基础 之 数据表示与特征工程 【分箱、离散化、线性模型与树 / 交互特征与多项式特征】的简单说明 一、简单介绍 二、分箱、离散化、线性…

【加密与解密(第四版)】第十七章笔记

第十八章 反跟踪技术 18.1 由BeginDebugged引发的蝴蝶效应 IsDebuggerPresent()函数读取当前进程PEB中的BeginDebugged标志 CheckRemoteDebuggerPresent() 反调试总结&#xff1a;https://bbs.kanxue.com/thread-225740.htm https://www.freebuf.com/articles/others-articl…

seata介绍及使用

什么是事务的ACID&#xff1f; 几种分布式事务解决方案&#xff1a; AT模式的二阶段提交&#xff1a; TCC模式的二阶段提交&#xff1a; 可靠消息最终一致性方案&#xff1a; SEATA部署&#xff1a; seata-server端下载&#xff1a; 修改seata/conf/file.conf配置文件&#xff…

各种各样的可视化流程图样式,大量案例来袭,设计不愁了。

在设计可视化流程图时&#xff0c;应该注重流程的清晰性和易读性&#xff0c;使用简洁明了的图形和标签&#xff0c;避免过于复杂和混乱的布局&#xff0c;使用户能够直观地理解和跟踪流程的步骤和路径。同时&#xff0c;根据具体的需求和用户群体&#xff0c;可以灵活运用颜色…

小微企业管理系统如何选择等保服务?

小微企业在选择等保&#xff08;信息安全等级保护&#xff09;服务时&#xff0c;应当考虑以下几个关键点以确保既能符合法规要求&#xff0c;又能在成本效益上做出合理决策&#xff1a; 了解等保需求&#xff1a;首先&#xff0c;小微企业需要了解自身的业务性质和信息系统的重…

【软件测试】5.测试用例

目录 1.测试用例 1.1概念 1.2测试的要素 2.测试用例的万能公式 2.1常规思考逆向思维发散性思维 2.2万能公式 2.2.1功能测试 2.2.2界面测试 2.2.3性能测试 2.2.4兼容性测试 2.2.5易用性测试 2.2.6安全测试 2.3弱网测试 1.测试用例 1.1概念 什么是测试用例&#xf…

梳理 JavaScript 中空数组调用 every方法返回true 带来惊讶的问题

前言 人生总是在意外之中. 情况大概是这样的. 前两天版本上线以后, 无意中发现了一个bug, 虽然不是很大, 为了不让用户使用时感觉到问题. 还是对着一个小小的bug进行了修复, 并重新在上线一次, 虽然问题不大, 但带来的时间成本还是存在的. 以及上线后用户体验并不是很好. 问题…

ArrayList与LinkedList

内存 内存缓存 预先将数据写到容器等数据存储单元中&#xff0c;就是软件内存缓存。 内存缓存淘汰机制 FIFO&#xff08;First in ,First Out&#xff09;&#xff08;先进先出&#xff09; LFU (Least Frequently Used) (频繁的最后淘汰) LRU(Least Recently Used) &#…

Lumines推出RGBL彩色混合LED

Luminus Devices倾心打造了一款崭新的4合1 RGBL&#xff08;红绿蓝绿石灰&#xff09;LED系列&#xff0c;专为舞台与建筑照明领域量身打造&#xff0c;满足对高显色指数&#xff08;CRI&#xff09;与高输出颜色混合的苛刻需求。这一创新之举&#xff0c;无疑是照明技术的一次…

K8S认证|CKA题库+答案| 7. 调度 pod 到指定节点

7、调度 pod 到指定节点 您必须在以下Clusterd/Node上完成此考题&#xff1a; Cluster Master node Worker node hk8s master …

DFA 算法

为什么要学习这个算法 前一段时间遇到了瓶颈&#xff0c;因为词库太多了导致会有一些速度过慢&#xff0c;而且一个正则表达式已经放不下了&#xff0c;需要进行拆分正则才可以。 正好我以前看过有关 dfa 的介绍&#xff0c;但是并没有深入的进行研究&#xff0c;所以就趁着周…

ubuntu22.04下 easyconnect+输入法安装

先使用对应ubuntu版本的easyconnect安装 sudo dpkg -i EasyConnect_x64_7_6_7_3.deb 下载压缩包servicePack&#xff0c;并解压缩 cd 下载路径/servicePack sudo cp * /usr/share/sangfor/EasyConnect/ 打开easyConnect /usr/share/sangfor/EasyConnect/EasyConnect 此处…

docker 安装 SonarQube

文章目录 docker 安装 SonarQube一、修改句柄二、创建挂载文件夹三、拉取镜像四、修改 PG 库4.1、创建用户4.2、创建库 五、启动和挂载六、访问七、安装插件 docker 安装 SonarQube 版本&#xff1a;8.9 对 JDK 8 最大支持为 8.9 版本 一、修改句柄 #修改文件句柄数量&#…

投骰子——(随机游戏的控制)

精华点在于&#xff1a;利用封装&#xff0c;函数之间的良好调用&#xff0c;从而清晰明了的解决问题。 #define _CRT_SECURE_NO_WARNINGS #include <stdio.h> # include<stdlib.h> # include<time.h> # include"math.h" # define ARR_LEN 10 # d…