数据结构与算法中的图

news2025/1/21 15:34:19

数据结构与算法中的图

图的定义与术语

线性结构之间,数据元素之间满足唯一的线性关系。每个数据元素(除第一个和最后一个外)只有一个****直接前趋和直接后继**
在树形结构中,数据元素之间有着明显的层次关系,并且每个数据元素只与上一层中的一个元素,(parenet node)及下一层中的多个元素(孩子节点)相关
(线性结构、树形结构、图形结构)
在图形结构中,节点之间的关系是任意的,图中的任意两个数据元素之间都有可能相关。因此说,图是一种复杂的非线性结构。

图用 G = ( V , E ) G = (V,E) G=(V,E)表示,其中:

  • V V V是顶点(vertex)的集合。
  • E E E是边(edge)的集合。
    根据图中的边是否有方向,可以分为有向图和无向图

无向图

对于一个图,若每条边都是没有方向的。则称该图为无向图
在这里插入图片描述

有向图

对于一个图,若每条边都是有方向的,则称该图为有向图
在这里插入图片描述

完全图

任意两个节点都有一条边相相连

稀疏图

很少边或弧的图,其指标为稀疏因子,若稀疏因子小于0.05,可认为是稀疏图。

密集图

有较多边或弧的图。

顶点的度

对于无向图,顶点的度表示以该顶点作为一个端点边的数目,比如上面的无向图,中顶点 V 3 V_3 V3的度 D ( V 3 ) = 3 D(V_3) = 3 D(V3)=3
对于有向图,顶点的度分为入度和出度。某一顶点的度等于其入读和出度之和

入度

入度表示以该顶点为终点的入边的数目

出度

出度以该顶点为起点的出边的数目

子图

在这里插入图片描述
在这里插入图片描述

路径

在这里插入图片描述
在这里插入图片描述
换句话说,路径都是从图上的一点出发,到图上另一点的方法
从图上的一点出发,到图上另一点的方法可能不止一个,即可能有多个路径。

回路

回路也称为环,简单来说,回路是指一条路径的终点和起点为同一个顶点。
在这里插入图片描述
无向图中,如果两个节点之间有平行边,容易让人误看作环

网络

带权重的连通图称为网
在这里插入图片描述

图的存储结构

相邻矩阵

图的相邻矩阵,或邻接矩阵,表示顶点之间的邻接关系。即有没有边。

有向图的相邻矩阵

在这里插入图片描述

无向图的相邻矩阵

在这里插入图片描述

邻接表

对于稀疏图,可以采用邻接表存储法。

  • 边较少,相邻矩阵就会出现大量的零元素
  • 相邻矩阵的零元素就会耗费大量的存储空间和时间。

顶点和边的信息如下:
在这里插入图片描述

无向图的邻接表示

无向图同一条边,在邻接表中出现两次
在这里插入图片描述
上面的图用邻接表可以表示:
在这里插入图片描述

带权图的邻接表表示

在这里插入图片描述
在这里插入图片描述

有向图的邻接表(出边表)

在这里插入图片描述
在这里插入图片描述

有向图逆邻接表(入边表)

在这里插入图片描述
在这里插入图片描述

十字链表

十字链表可以看作是邻接表和逆邻接表的结合
对应于有向图的每一条弧有一个条目:共有5个域:

  • 头 : headvex
  • 尾:tailvex
  • 下一条共尾弧:tailnextarc
  • 下一条共弧: headnextarc
  • 弧权值等info域。

顶点表目有3个域组成:

  • data 域
  • firstinarc 第一条以该顶点为终点的弧
  • firstoutarc 第一条以该顶点为始点的弧
    在这里插入图片描述
    十字链表有两组链表组成:
  • 行和列的指针序列
    每个结点都包含两个指针:
  • 同一行的后继
  • 同一列的后继
    在这里插入图片描述

图的遍历

图的遍历是给出一个图 G G G和其中的任意一个顶点 V 0 V0 V0,从 V 0 V0 V0出发系统的访问 G G G中的所有的顶点,每个顶点访问而且只访问一次。

从一个顶点出发,试探性的访问其余顶点,同时必须考虑到下列情况:

  • 从一个顶点出发,可能不能到达所有其他的顶点,如非连通图。
  • 也有可能会陷入死循环,如存在回路的图
    一般情况下,可以为每个顶点保留一个标志位:
  • 算法开始时,所有顶点的标志位置零。
  • 在遍历过程中,当某个顶点被访问时候,其标志位就会被标记为已访问。

深度优先遍历

深度优先搜索(简称DFS) 类似于树的先根次序遍历,尽可能先对纵深方向进行搜索:

** 选取一个未访问的点 v 0 v0 v0 作为源点

  • 访问顶点$ v0$
  • 递归地深搜遍历 $v0 $邻接到的其他顶点
  • 重复上述过程直至从 $v0 $有路径可达的顶点都已被访问过
  • 再选取其他未访问顶点作为源点做深搜,直到图的所有顶点都被访问过

在这里插入图片描述
深度优先遍历的顺序是:
在这里插入图片描述

广度优先遍历

*** 广度优先搜搜**,其遍历过程是:

  • 从图中的某个顶点 v0 出发
  • 访问并标记了顶点 v0 之后
  • 一层层横向搜索 v0 的所有邻接点
  • 对这些邻接点一层层横向搜索,直至所有由 v0 有路径可达的顶点都已被访问过
  • 再选取其他未访问顶点作为源点做广搜,直到所有点都被访问过
    在这里插入图片描述
    广度优先搜索的顺序是:
    在这里插入图片描述

最短路径

单源最短路径

在这里插入图片描述

迪杰斯特拉算法

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
算法单源最短路径迭代过程:
在这里插入图片描述
该算法是贪心法, 不适用于负权值的情况,因为权直当做最小取进来后,不会返回去重新计算,即使不存在负的回路,也可能有在后面出现的负权值,从而导致整体计算错误。

每对结点间的最短路径

Floyd算法对每对结点之间的最短路径。
用邻接矩阵adj来表示带权有向 图

基本思想

在这里插入图片描述

最小生成树

G G G的生成树是一颗包含所有顶点的树,树上的所有权值总和表示代价,那么在 G G G的所有的生成树中,代价最小的生成树,称为 G G G的最小生成树。

在这里插入图片描述

总结

不用太在意,慢慢的总结完整后,开始研究图结构及其存储,全部将其搞定都行啦的样子与打算。
不用太在意,其他的学习,要学会用可以用计算机自动计算出来‘
先助攻研读论文在说其他的样子域打算。

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

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

相关文章

实验四、R_b变化对Q点和电压放大倍数的影响 ​

一、题目 研究 RbR_bRb​ 变化对 QQQ 点和 A˙u\dot A_uA˙u​ 的影响。 二、仿真电路 仿真电路如图1(b)、(ccc)所示。晶体管采用 FMMT5179。其datasheet的相关参数如下:(a)FMMT5179的参数(a)\textrm{FMMT5179}的参数(a)FMMT5179的参数 (b)Rb为3MΩ时的情况(b)R…

RDD——Action算子

常用Action算子 countByKeycollectreducefoldfirsttaketopcounttakeSampletakeOrderedforeachsaveAsTextFile countByKey() 返回值是一个 字典类型 ## 读取文本文件 rdd1 sc.textFile(f"file:///{ROOT}/data/input/words.txt") rdd2 rdd1.flatMap(lambda x:x.spl…

【数字信号去噪】小波软阈值+硬阈值+改进阈值数字信号去噪【含Matlab源码 1025期】

⛄一、小波语音降噪简介 对于噪声频谱遍布于语音信号频谱之中的宽带噪声,如果噪声振幅比大部分的语音信号振幅低,则削去低幅度成分也就削去了宽带噪声。基于这种思路,可以在频域中采取中心限幅的方法,即让带噪语音信号通过一限幅…

实战关于登录框的渗透测试

前言 登录框可以说是我们漏洞挖掘中最常见的点,漏洞的种类也是相当的多,相信大家在登录框中发现的漏洞数不胜数。 主要有以下这些漏洞 弱口令 SQL注入 水平越权 垂直越权 逻辑漏洞 短信轰炸 邮箱轰炸 信息泄露SQL注入 看到登录框,输入信…

C++智能指针之weak_ptr

C智能指针之weak_ptr前言weak_ptr总结前言 在C中,动态内存的申请和释放是通过运算符:new 和 delete 进行管理的。其中 new 负责申请内存,delete负责释放内存。 动态内存的使用很容易出现问题,这主要在于你需要保证在正确的时间释放…

【MAX78000基础案例演示】

【MAX78000基础案例演示】1. MAX78000配套软硬件1.1 硬件1.2 软件1.3 demo例程2. ADC2.1 描述2.2 设置2.3 输出3. GPIO3.1 描述3.2 设置3.3 输出4. UART4.1 描述4.2 设置4.3 输出6.小结1. MAX78000配套软硬件 有关使用 SDK 的详细信息,请参阅MAX78000 评估套件入门…

(附源码)计算机毕业设计Java巴音学院学生资料管理系统

项目运行 环境配置: Jdk1.8 Tomcat8.5 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。 项目技术: Springboot mybatis Maven Vue 等等组成,B/…

Android Parcelable反序列化漏洞分析与利用

文章目录前言背景知识Parcelable序列化Bundle的数据结构LaunchAnyWhereCVE-2017-13288漏洞利用原理解析POC程序攻击演示CVE-2017-13315漏洞利用原理解析POC程序攻击演示漏洞Demo思考漏洞利用原理解析POC程序(供参考)总结前言 今年年初曾关注到 heen 大佬在 2018 年中旬写的一篇…

3-6数据链路层-广域网

广域网(WAN,Wide Area Network),通常跨接很大的物理范围,所覆盖的范围从几十公里到几千公里,它能连接多个城市或国家,或横跨几个洲并能提供远距离通信,形成国际性的远程网络。 文章目录一.基本概…

本周总结(11.21-11.27)

周一: ssm项目写了委托 写的过程中边写边学习了一些布局用法。 周二: ssm项目写了查看 这部分内容主要还是在前端上改了很久,首先就是因为三种房源各不相同,每个房源都需要创建一个表,数据也不一致,所以详细房源页面…

ps常用操作

ps常用操作 个人总结,半路出家,仅供个人习惯,仅供个人参考。1.如何将导入的图片放大??? ctrl 和 加号 2.如何去除阴影或者粗糙的地方? 第一种方式,选择图像,选择填充 …

进军东南亚市场,腾讯云数据库 TDSQL 助力印尼 BNC 银行数字化转型

腾讯云数据库在助力金融核心系统分布式替换上,已经辐射到了东南亚市场。 东南亚最大的银行之一印尼BNC银行(Bank Neo Commerce)已正式完成新核心分布式迁移,使用腾讯云数据库TDSQL后,系统运行平稳顺畅。这标志着腾讯云…

电机与拖动 - 2 变压器

2 变压器2.1 变压器的用途与种类2.3 变压器基本结构2.4 变压器型号与额定值2.2 变压器工作原理2.5 变压器的等效电路2.6 变压器的参数测定 2 变压器 2.1 变压器的用途与种类 变压器用途:本课程讨论变换交流的电压幅值,不改变频率与电压交直流类型。电厂…

HBase安装部署

首先,启动Zookeeper 集群 启动Hadoop集群 HBase 的解压 更名 配置环境变量 添加 #HBASE_HOME export HBASE_HOME/opt/module/hbase export PATH$PATH:$HBASE_HOME/bin注意路径和你配置的hbase安装路径相同,不要直接抄 source一下 让配置的环境变量…

【Android】App开发-动画效果篇

在我们玩手机的过程中,如果我们点击某一个页面时,会出现一个页面动画加载或者动画效果的现象。现在我们就来看看App开发中是如何实现动画效果的。 目录 动画的分类 逐帧动画: 补间动画: 动画的分类 在常见的app使用的动画中&…

面试:事件拦截相关问题

Q1:分发的事件被view消耗了,后续事件是如何快速找到这个view的? ViewGroup不拦截事件又是如何将事件分发给子View? 带着问题重学Android事件分发 - 掘金 我们之前经常背的八股文: 当你手指触摸到屏幕这时候ViewGro…

BUUCTF Misc 隐藏的钥匙 另外一个世界 FLAG 神秘龙卷风

隐藏的钥匙 下载文件 使用010 editor工具查看 查找flag 将内容复制到base64在线 得到flag flag{377cbadda1eca2f2f73d36277781f00a} 另外一个世界 下载文件 使用010 eitor查看 看到了一串二进制,进行二进制转换字符串 得到flag flag{ko…

XCTF1-web unseping

unseping 题目描述 进入场景 源代码分析&#xff0c;反序列化场景 <?php highlight_file(__FILE__);class ease{private $method;private $args;function __construct($method, $args) {$this->method $method;$this->args $args;}function __destruct(){if (in_…

FPGA 20个例程篇:18.SD卡存放音频WAV播放(上)

第七章 实战项目提升&#xff0c;完善简历 18.SD卡存放音频WAV播放&#xff08;上&#xff09; 在最后一章里&#xff0c;我们来做几个实战项目&#xff0c;一方面是对前面学习知识的一种回顾&#xff0c;另一方面这几个小项目也非常贴近实际工程&#xff0c;其中例程“SD卡存…

CENTOS安装 graylog4.39

我们直接开始 基础环境和java sudo yum install epel-release 并安装带有 sudo yum install pwgenyum install java-1.8.0-openjdk-headless.x86_64 MONGODB 安装数据库 vi /etc/yum.repos.d/mongodb-org.repo[mongodb-org-4.2] nameMongoDB Repository baseurlhttps://rep…