【数据结构】06图

  • 1. 定义
    • 1.1 无向图和有向图
    • 1.2 度、入度和出度
    • 1.3 图的若干定义
    • 1.4 几种特殊的图
  • 2. 图的存储
    • 2.1 邻接矩阵-顺序存储(数组)
    • 2.2 邻接表-顺序存储+链式存储(数组+链表)
    • 2.3 十字链表-适用于有向图
    • 2.4 邻接多重表-适用于无向图
  • 3. 图的基本操作
    • EdgeExist(G,v,w)
    • AllAdjVex(G,v)
    • InsertVex(G,v)
    • DeleteVex(G,v)
    • InsertEdge(G,v,w)
  • 4. 图的遍历
    • 4.1 广度优先搜索(BFS)
    • 4.2 深度优先搜索(DFS)

1. 定义

(Graph)是一种比线性表和树更复杂的数据结构。在线性表中,数据元素之间是一对一的关系,每个数据元素只有一个直接前驱和一个直接后继。在树形结构中,数据元素之间有明显的层次关系,上一层的数据元素(结点)和下一层的数据元素(结点)是一对多的关系。而在图形结构中,数据元素之间的关系是任意的,是多对多的关系。
在图中,数据元素通常称作顶点(Vertex),简称V,是有穷非空的集合,记为 V = { v 1 , v 2 , . . . v n } V=\{v_1,v_2,...v_n\} V={v1,v2,...vn},|V|表示顶点个数。两个顶点之间的关系称作(Edge),简称E,是有穷的集合,记为 E = ( u , v ) ∣ u ∈ V , v ∈ V E={(u,v)|u\in{V},v\in{V}} E=(u,v)uV,vV,|E|表示边的条数。
图简称G,由顶点集V和边集E组成,记作G=(V,E)
在这里插入图片描述
第三幅图不是图的数据结构

1.1 无向图和有向图

在这里插入图片描述
图G1中,每条边是没有方向的(无向边),则图G1是无向图。
图中的边是顶点的无序对,例如顶点V1和V2之间的边,记作(V1,V2)或(V2,V1)都可以。
G1=(V1,E1)
V1={V1,V2,V3,V4,V5}
E1={(V1,V2),(V1,V3),(V2,V4),(V3,V5)}
在这里插入图片描述
图G2中,每一条边是有方向的(有向边),则图G2是有向图
图中的边是顶点的有序对,例如顶点V2和V1之间的边只能记作<V2,V1>
G2={V2,E2}
V2={V1,V2,V3,V4,V5}
E2={<V2,V1>,<V1,V3>,<V3,V5>,<V5,V3>}
有向边也称为,<V2,V1>称为顶点V2到顶点V1的弧。V2是弧尾(初始点),V1是弧头(终端点)。顶点V2邻接到顶点V1。
简单图:不存在重复的边,不存在顶点到自身的边

1.2 度、入度和出度

无向图:

  • 顶点的度:与该顶点关联的边的条数。图G1中,TD(V1)=2,TD(V2)=2…
  • 无向图中全部顶点的度的和=边数X2

有向图:

  • 入度:以该顶点为终点的边的条数:ID(V1) = 1,TD(V2)=0
  • 出度:以该顶点为起点的边的条数:OD(V1)=1,OD(V2)=1
  • 度:顶点的度是该顶点的入度和出度之和,TD(V1)=ID(V1)+OD(V1)=2
  • 有向图中全部顶点的入度之和等于出度之和

1.3 图的若干定义

路径:从顶点Vx到Vy的顶点序列
回路:第一个顶点和最有一个顶点相同的路径成为回路或环
简单路径:在路径的序列中,顶点没有重复出现
简单回路:除第一个顶点和最后一个顶点外,其他顶点没有重复出现
路径长度:路径上边的条数
顶点到顶点的距离:顶点之间最短路径的长度,如果不存在路径,记为无穷 ∞ \infin
在无向图中,如果顶点Vx到顶点Vy有路径,表示Vx和Vy是连通的。
在有向图中,如果顶点Vx到顶点Vy和顶点Vy到顶点Vx都有路径,表示Vx和Vy是强连通的。
连通图:任意两个顶点都是连通的。
强连通图:任意两个顶点都是强连通的。
生成子图:生成子图包含了原图的全部顶点和若干条边
连通分量:无向图中,极大的连通子图称之为连通分量(是连通子图 每个连通子图尽可能包含更多的顶点和边)
强连通分量:有向图中,极大的强连通子图称之为强连通分量(是强连通子图 每个强连通子图金肯包含更多的顶点和边)
生成树:无向连通图中,生成树是指包含了全部顶点的极小连通子图(连通图 全部顶点 边最少)
带权图:在一个图中,边可以表示某种含义的数值,例如顶点之间的距离,该数值称为边的权值。如果图的边上带了权值,那么该图称为带权图,或网。带权图中,某条路径上全部边的权值之和,称为该路径的带权路径长度。

1.4 几种特殊的图

  • 完全图
    • 无向完全图:图中任意两个顶点都存在一条边
    • 有向完全图:图中任意两个顶点都存在方向相反的两条边
  • 稀疏图和稠密图:边很少的图称为稀疏图,反之称为稠密图
  • 树:不存在回路的连通无向图
  • 有向树:有且仅有一个结点的入度为0,除树根外的结点入度为1,从树根到任一结点有一条有向通路

2. 图的存储

图的存储方式有四种:邻接矩阵、邻接表、十字链表、邻接多重表

2.1 邻接矩阵-顺序存储(数组)

图的邻接矩阵(Adjacency Matrix)存储方式是用两个数组来表示图。一个一维数组存储顶点信息,一个二维数组(称为邻接矩阵)存储图中的边或弧的信息。
在这里插入图片描述
在这里插入图片描述

  • 对于图:结点之间有连接则边表中对应项记为1,无连接则记为0。但是无向图是A-C和C-A都有,然而有向图则只有C-A没有A-C,需要看清方向。
  • 在无向图的邻接矩阵中,顶点的度为该顶点所在行或列中非零元素的个数。
  • 在有向图的邻接矩阵中,顶点的出度为该顶点所在中的非零元素的个数,入度为该顶点所在中的非零元素个数。顶点的度=出度+入度
    对于A顶点:无向图的度=3,有向图的度=1+2=3
  • 对于带权图,把每条边的权值存入邻接矩阵,如果顶点之间不存在边存入无穷表示
// 利用邻接矩阵存储图
typedef char VertType; // 定义顶点的数据类型
typedef int EdgeType; // 定义边权的数据类型
#define MAXVNUM 100 // 顶点的最大数值
#define INFINITY 65536 // 无穷常量,也可以用边的权值不可能出现的值struct MGraph
{VertType vexs[MAXVNUM]; // 顶点表EdgeType edges[MAXVNUM][MAXVNUM]; // 带权边表,邻接矩阵int vexnum, arcnum; // 顶点数|V|和边数|E|
};

2.2 邻接表-顺序存储+链式存储(数组+链表)

顶点的信息存放在一维数组中,每个顶点的边的信息存放在边链表中。
在这里插入图片描述

// 边链表结构体
struct ENode
{int adjvex; // 邻接点域,存储该顶点对应的下标EdgeType info; // 存储权值ENode* next; // 指针域,指向下一个邻接顶点
};
// 顶点结构体
struct VNode 
{VertType data; // 数据域,存储顶点信息ENode* first; // 边表头指针
};
// 图的结构体
struct AdjListGraph
{VNode vexs[MAXVNUM]; //顶点数组int vexnum,arcnum; // 顶点数和边数
};

2.3 十字链表-适用于有向图

十字链表就是有两个边链表的邻接表。
在这里插入图片描述

2.4 邻接多重表-适用于无向图

1)边链表结点有冗余,无向图中对于A-B之间的边,在A的边链表中有B,在B的边链表中有A,只需要一个就能表达含义了。
2)删除边和顶点操作很麻烦,时间复杂度高。
在这里插入图片描述

3. 图的基本操作

EdgeExist(G,v,w)

判断图G中是否存在从顶点v到顶点w的边,(v,w)或<v,w>,如(G,C,D)。

  • 邻接矩阵:检查C行D列是否为1。
  • 邻接表中:检查C顶点的边链表中是否有顶点D。

AllAdjVex(G,v)

列出图G中与顶点v邻接的边,如(G,C)
对于无向图:

  • 邻接矩阵:检查C整(行)列,输出为1对应的顶点
  • 邻接表:检查顶点C的边链表,输出顶点。

对于有向图:邻接的边包括出边和入边

  • 邻接矩阵:检查C整行,输出为1对应的顶点(出边);检查C整列,输出为1对应的顶点(入边)。
  • 邻接表:访问顶点C对应的边链表,输出顶点(出边);依次访问每个顶点(除C自身)的边链表,如果有C,则输出该顶点(入边)。

InsertVex(G,v)

在图G中插入顶点v,此时不需要插入边,只用插入顶点。

DeleteVex(G,v)

从图G中删除顶点v,如(G,C)。删除顶点C。(真删除和伪删除)
对于无向图:

  • 邻接矩阵:删除顶点表中的C,后续元素前移;邻接矩阵中删除C对应的行列,并移动元素
  • 邻接表:删除顶点表中的C,以及对应的边链表。还要遍历其他顶点,删除边链表中的C

InsertEdge(G,v,w)

在图G中插入一条从顶点v到w的边。如(G,C,D)
无向图

  • 邻接矩阵:C行D列和D行C列都需要置为1
  • 邻接表:顶点C的边链表中插入新结点D;顶点D的边链表中插入新结点C。
    有向图:
  • 邻接矩阵:C行D列置为1
  • 邻接表:顶点C的边链表中插入新结点D

4. 图的遍历

4.1 广度优先搜索(BFS)

图的广度优先搜索类似于树的层次遍历,需要使用一个辅助队列和辅助数组(用于记录已经访问过的数组)来实现
在这里插入图片描述
图的遍历可以从任意一个结点开始,假设从顶点2开始。顶点2入队,并查找visited数组中对应的下标是否已经访问,没有置为true。
在这里插入图片描述
出队队头元素,并将其邻接点未访问顶点入队,包括5,6,3,1
在这里插入图片描述
出队队头元素,并将其邻接点未访问顶点入,5出队后没有入队,6出队后入队7
在这里插入图片描述出队队头元素,并将其邻接点未访问顶点入,3出队后没有元素入队,1出队后入队4
在这里插入图片描述
出队队头元素,并将其邻接点未访问顶点入,7出队后没有元素入队,4出队后入队8,9
在这里插入图片描述
出队队头元素,8,9。队列为空,遍历完成。

4.2 深度优先搜索(DFS)

图的深度优先搜索与图的先序遍历类似。可以利用递归或者栈的形式实现。具体就不在这里展开了。

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

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

相关文章

第10章 物理安全要求

10.1 站点与设施设计的安全原则 假如没有对物理环境的控制&#xff0c;任何管理的、技术的或逻辑的访问控制技术都无法提供足够的安全性。 如果怀有恶意的人员获取了对设施及设备的物理访问权&#xff0c;那么他们几乎可以为所欲为&#xff0c;包括肆意破坏或窃取、更改数据。…

react antd 实现修改密码(原密码,新密码,再次输入新密码,新密码增加正则复杂度校验)

先看样子 组件代码&#xff1a; import React, { useState, useEffect } from react import { Row, Col, Modal, Spin, Input, Button, message, Form } from antd import { LockOutlined, EyeTwoTone, EyeInvisibleOutlined } from ant-design/icons import * as Serve from …

力扣练习题(2024/4/15)

1打家劫舍 你是一个专业的小偷&#xff0c;计划偷窃沿街的房屋。每间房内都藏有一定的现金&#xff0c;影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统&#xff0c;如果两间相邻的房屋在同一晚上被小偷闯入&#xff0c;系统会自动报警。 给定一个代表每个房屋…

C++ - set 和 map详解

目录 0. 引言 1. 关联式容器 2. 键值对 3. 树形结构 4. set 4.1 set 的定义 4.2 set 的构造 4.3 set 的常用函数 4.4 set 的特点 5. multiset 5.1 multiset 插入冗余数据 5.2 multiset - count 的使用 6. map 6.1 map 的定义 6.2 map 的构造 6.3 map的常…

Python基于Django的微博热搜、微博舆论可视化系统

博主介绍&#xff1a;✌IT徐师兄、7年大厂程序员经历。全网粉丝15W、csdn博客专家、掘金/华为云//InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精彩专栏推荐订阅&#x1f447;&#x1f3…

银河麒麟高级服务器操作系统adb读写缓慢问题分析

1.问题环境 处理器&#xff1a; HUAWEI Kunpeng 920 5251K 内存&#xff1a; 512 GiB 整机类型/架构&#xff1a; TaiShan 200K (Model 2280K) BIOS版本&#xff1a; Byosoft Corp. 1.81.K 内核版本 4.19.90-23.15.v2101.ky10.aarch64 第三方应用 数据库 2.问题…

数据可视化高级技术Echarts(桑基图入门)

目录 一、什么是桑基图 二、基本特征 三、设计注意事项 四、使用Echarts进行初级绘制 1.首先不能忘记五个基本步骤 2.绘制的时需要将图像类型series.type设定为sankey类型。 一、什么是桑基图 桑基图&#xff08;Sankey diagram&#xff09;&#xff0c;即桑基能量分流图&…

【高录用-快速见刊】2024年数字化经济与金融创新国际学术会议(ICDEFI 2024)

会议简介 2024年数字经济与金融创新国际学术会议即将召开。此次会议旨在汇集全球数字经济与金融创新领域的专家学者&#xff0c;共同探讨数字经济的发展趋势以及金融创新的路径。与会者将分享前沿研究成果&#xff0c;讨论数字技术在金融领域的应用与创新&#xff0c;并推动数…

主线程捕获子线程异常

正常情况下使用多线程出现异常时&#xff0c;都是按照单个任务去处理异常&#xff0c;在线程间不需要通信的情况下&#xff0c;任务之间互不影响&#xff0c;主线程也不必知道子线程是否发成异常。 那么只需要处理子线程异常即可 Task.Run(() > {try{throw new Exception(&…

OpenHarmony轻量系统开发【2】源码下载和开发环境

2.1源码下载 关于源码下载的&#xff0c;读者可以直接查看官网&#xff1a; https://gitee.com/openharmony/docs/tree/master/zh-cn/release-notes 本文这里做下总结&#xff1a; &#xff08;1&#xff09;注册码云gitee账号。 &#xff08;2&#xff09;注册码云SSH公钥…

112 arcpy 发布 mxd地图文件 到 arcgis服务器 为 地图服务

前言 此文档主要是记录一下 最近的一次机遇 arcpy 来发布 地图文件到 arcgis服务器 上面 arcpy 主要是来自于 ArcGIS_Desktop_105_154030.zip 安装之后会在 python 的安装目录 安装另外的一份带 arcgis 的 python 环境, 然后 本文相关类库 也是基于 这个 arcpy 的 python 环境…

jenkins(docker)安装及应用

jenkins Jenkins是一个开源的、提供友好操作界面的持续集成(CI)工具&#xff0c;起源于Hudson&#xff08;Hudson是商用的&#xff09;&#xff0c;主要用于持续、自动的构建/测试软件项目、监控外部任务的运行&#xff08;这个比较抽象&#xff0c;暂且写上&#xff0c;不做解…

【算法刷题 | 回溯思想 04】4.15(分割回文串)

文章目录 7.分割回文串7.1题目7.2解法&#xff1a;回溯7.2.1回溯思路&#xff08;1&#xff09;函数返回值以及参数&#xff08;2&#xff09;终止条件&#xff08;3&#xff09;遍历过程 7.2.2代码 7.分割回文串 7.1题目 给你一个字符串 s&#xff0c;请你将 s 分割成一些子…

【蓝桥·算法双周赛 第 9 场 小白入门赛】盖印章【算法赛】题解(数学+解方程)

思路 考虑到题目中的规则&#xff0c;每个印章图案的边必须和网格图边重合&#xff0c;网格图上的每一个格子最多只能被一个印章图案覆盖&#xff0c;印章的图案在网格图上必须是完整的。这意味着每个印章图案都会覆盖一个独立的、完整的区域&#xff0c;且这些区域不会相互重…

OpenHarmony实战开发-页面深色模式适配。

介绍 本示例介绍在开发应用以适应深色模式时&#xff0c;对于深色和浅色模式的适配方案&#xff0c;采取了多种策略如下&#xff1a; 1. 固定属性适配&#xff1a;对于部分组件的颜色属性&#xff0c;如背景色或字体颜色&#xff0c;若保持不变&#xff0c;可直接设定固定色值…

Linux网络基础(一)

网络发展 对于我们国家来讲&#xff0c;网络的发展&#xff0c;不仅仅是互联网公司在发展&#xff0c;提供重要推动力的还有三大运商 随之而来的是新设备的诞生。比如集线器&#xff0c;网线&#xff0c;光纤&#xff0c;调制解调器&#xff0c;路由器&#xff0c;防火墙&am…

Nginx转发请求错误

说明&#xff1a;记录一次使用Nginx转发请求的错误&#xff1b; 场景 公司内部有两台服务器都跑了后端项目&#xff0c;在使用Nginx做请求分发时&#xff0c;我发现其中有台服务器一直没有处理请求&#xff08;没打印相关的日志信息&#xff09;&#xff0c;于是我修改了下Ng…

NVIDIA全系列GPU技术路线演进分析

NVIDIA GPU 架构梳理 近期深入研究并行计算&#xff0c;需探究底层硬件精髓。高性能计算界&#xff0c;英伟达显卡稳居霸主地位。本文旨在梳理NVIDIA GPU架构之演进历程&#xff0c;助您洞悉其技术脉络&#xff0c;把握未来计算趋势。 目录&#xff1a; NVIDIA GPU架构历经数次…

代码随想录Day41:动态规划Part3

Leetcode 343. 整数拆分 讲解前&#xff1a; 毫无头绪 讲解后&#xff1a; 这道题的动态思路一开始很不容易想出来&#xff0c;虽然dp数组的定义如果知道是动态规划的话估摸着可以想出来那就是很straight forward dp定义&#xff1a;一维数组dp[i], i 代表整数的值&#xf…

WEB前端-笔记

目录 一、字体 二、背景图片 三、显示方式 四、类型转换 五、相对定位 六、绝对定位 七、固定定位 八、Index 九、粘性定位 十、内边距 十一、外边距 十二、边框 十三、盒子尺寸计算问题 十四、清楚默认样式 十五、内容溢出 十六、外边距的尺寸与坍塌 十七、行…