离散数学--图论

目录

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.rhkb.cn/news/329656.html

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

相关文章

vue项目报错:internal/modules/cjs/loader.js:892 throw err;

前言&#xff1a; vue项目中无法正常使用git&#xff0c;并报错情况。 报错信息&#xff1a; internal/modules/cjs/loader.js:892throw err;^ Error: Cannot find module D:\project\sd_wh_yth_front\node_modules\yorkie\src\runner.js 报错处理&#xff1a; npm install y…

局部直方图均衡化去雾算法

目录 1. 引言 2. 算法流程 3. 代码 4. 去雾效果 1. 引言 局部直方图算法是一种基于块的图像去雾方法&#xff0c;它将图像分割为若干个块&#xff0c;并在每个块内计算块的局部直方图。通过对各个块的直方图进行分析和处理&#xff0c;该算法能够更好地适应图像中不同区域的…

九宫格转圈圈抽奖活动,有加速,减速效果

在线访问demo和代码在底部 代码&#xff0c;复制就可以跑 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><tit…

Git远程控制

文章目录 1. 创建仓库1.1 Readme1.2 Issue1.3 Pull request 2. 远程仓库克隆3. 推送远程仓库4. 拉取远程仓库5. 配置Git.gitignore配置别名 使用GitHub可以&#xff0c;采用Gitee也行 1. 创建仓库 1.1 Readme Readme文件相当于这个仓库的说明书&#xff0c;gitee会初始化2两份…

解除网页禁止选择

控制台输入以下命令 复制&#xff1a;javascript:void(document.body.οncοpy) 可选&#xff1a;javascript:void(document.body.onselectstart) 拖拉&#xff1a;javascript:void(document.body.οnmοuseup)

好的架构是进化来的,不是设计来的

很多年前&#xff0c;读了子柳老师的《淘宝技术这十年》。这本书成为了我的架构启蒙书&#xff0c;书中的一句话像种子一样深埋在我的脑海里&#xff1a;“好的架构是进化来的&#xff0c;不是设计来的”。 2015 年&#xff0c;我加入神州专车订单研发团队&#xff0c;亲历了专…

Android ART 虚拟机简析

源码基于&#xff1a;Android U 1. prop 名称选项名称heap 变量名称功能 dalvik.vm.heapstartsize MemoryInitialSize initial_heap_size_ 虚拟机在启动时&#xff0c;向系统申请的起始内存 dalvik.vm.heapgrowthlimit HeapGrowthLimit growth_limit_ 应用可使用的 max…

先进电气技术 —— 控制理论中的“观测器”概述

一、背景 观测器在现代控制理论中的地位十分重要&#xff0c;它是实现系统状态估计的关键工具。观测器的发展历程可以从以下几个方面概述&#xff1a; 1. 起源与发展背景&#xff1a; 观测器的概念源于对系统状态信息的需求&#xff0c;特别是在只能获取部分或间接输出信息…

如何在.NET中集成SignalR

SignalR 简介 SignalR是一个开放源代码库&#xff0c;可用于简化向应用添加实时Web功能&#xff0c;实时Web功能使服务器端代码能够将内容推送到客户端。 SignalR开源库&#xff1a;https://github.com/SignalR/SignalR SignalR 应用场景 需要高频次从服务器获取信息的应用&am…

java-spring 14 项目启动过程

Spring的启动流程可以归纳为三个步骤&#xff1a; 1、初始化Spring容器&#xff0c;注册内置的BeanPostProcessor的BeanDefinition到容器中 2、将配置类的BeanDefinition注册到容器中 3、调用refresh()方法刷新容器 // 初始化容器 public AnnotationConfigApplicationContex…

弘君资本股市技巧:限售股解禁对市场有何影响?

限售股解禁意味着本来不能在商场上自由生意的股票能够进入二级商场流通了&#xff0c;限售股解禁往往会引起投资者们的高度关注。关于限售股解禁对商场有何影响&#xff0c;弘君资本下面就为大家具体介绍一下。 限售股解禁的影响&#xff1a; 1、股价跌落压力增大。当限售股解…

二.常见算法--贪心算法

&#xff08;1&#xff09;单源点最短路径问题 问题描述&#xff1a; 给定一个图&#xff0c;任取其中一个节点为固定的起点&#xff0c;求从起点到任意节点的最短路径距离。 例如&#xff1a; 思路与关键点&#xff1a; 以下代码中涉及到宏INT_MAX,存在于<limits.h>中…

彩色进度条(C语言版本)

.h文件 #include<stdio.h> #include<windows.h>#define NUM 101 #define LOAD_UP 50 #define LOAD_DOWN 60 #define SLEEP_SLOW 300 #define SLEEP_FAST 70 版本1&#xff1a;&#xff08;初始版&#xff09; //v1 #include "progress.h" int main() …

【云原生】Kubernetes基础命令合集

目录 引言 一、命令概述 &#xff08;一&#xff09;命令分类 &#xff08;二&#xff09;基本语法 二、查看基本信息 &#xff08;一&#xff09;环境指令 1.查看版本信息 2.查看资源对象简写 3.添加补全信息 4.查看日志 5.查看集群信息 &#xff08;二&#xff0…

vue打包部署到springboot,通过tomcat运行

tomcat默认端口 8080springboot端口 9132vue 端口 9131 框架 项目是基于SpringBootVue前后端分离的仓库管理系统 后端&#xff1a;SpringBoot MybatisPlus前端&#xff1a;Node.js Vue element-ui数据库&#xff1a;mysql 一. 打包Vue项目 cmd中输入命令 npm run build 后…

【施磊】C++语言基础提高:深入学习C++语言先要练好的内功

课程总目录 文章目录 一、进程的虚拟地址空间内存划分和布局二、函数的调用堆栈详细过程三、程序编译链接原理1. 编译过程2. 链接过程 一、进程的虚拟地址空间内存划分和布局 任何的编程语言 → \to → 产生两种东西&#xff1a;指令和数据 编译链接完成之后会产生一个可执行…

python将程序运行结果存入txt文本

//其实就是运行下面代码&#xff0c;然后下面代码会通过subprocess再去运行script.py&#xff08;我们的程序代码&#xff09;&#xff0c;然后把它写入oput.txt中。 import subprocess with open(oput.txt, w) as f:subprocess.run([python, script.py], stdoutf, stderrsu…

XX数字中台技术栈及能力

XX数字中台技术栈及能力 1 概述 XX数字中台面向数据开发者、数据管理者和数据应用者&#xff0c;提供数据汇聚、融合、治理、开发、挖掘、共享、可视化、智能化等能力&#xff0c;实现数据端到端的全生命周期管理&#xff0c;以共筑数字基础底座&#xff0c;共享数据服务能力…

酷开系统 | 酷开科技把握智慧先机 AI赋能家庭场景

智慧化是当今世界科技发展的前沿领域之一。现在的智慧化&#xff0c;也正在逐步成为我们日常生活的一部分。电视系统也进入了数字化时代&#xff0c;AI的应用正在不断扩展&#xff0c;其潜力似乎无穷无尽。 酷开科技深耕人工智能技术&#xff0c;在提升语音体验、强化智能家居…

目前流行的前端框架有哪些?

目前流行的前端框架有很多&#xff0c;它们可以帮助开发者快速构建高质量的前端应用程序。本文将介绍一些目前比较受欢迎的前端框架&#xff0c;并分析它们的优缺点。 React React 是一个由 Facebook 开发的开源前端JavaScript库&#xff0c;用于构建用户界面&#xff0c;尤其…