【数据结构】图的基本概念—无/有向图、权和网、完全图、路径与回路

简介: 【数据结构】图的基本概念—无/有向图、权和网、完全图、路径与回路

前言


97ee575c9c224988b678649262ff33fb.png


提起数据结构,大家最熟悉的恐怕就是数组、链表、二叉树。而对于“图”这种数据结构,很多人只停留在“听说过”阶段。但是,图也是一种非常重要,而且跟现实息息相关的数据结构。


比如,我们在使用百度、高德地图做导航的时候,城市的地图就是一种图结构;当我们用微信、QQ等社交软件的时候,我们的好友关系网也是一种图结构。


图,是一种比树更为复杂的数据结构,树的节点之间是一对多的关系,并且存在父与子的层级划分,而图的顶点(注意在此不叫节点)之间是多对多的关系,并且所有顶点都是平等的,无所谓谁是父谁是子。


举个例子,微信中许许多多的用户组成了一个多对多的朋友关系网,这个关系网就是数据结构中的图(Graph)。


b34db82f459841c2ab6dc65f64eb386d.png


让我们来详细了解一下图的底蕴吧!

💚❤️💙💚❤❤️💙💚❤️❤💙💚❤️💙❤💚❤️💙💚❤❤️💙💚❤️❤💙❤️💙💚❤


🐋基本概念

❣️❣️什么是图?

图,是一种用节点和边来表示相互关系的数学模型。


简单的说,点用边连起来就叫做图,严格意义上讲,图是一种数据结构,通常表示为:G=(v,E),其中,G表示一个图,v是图G中顶点的有穷非空集合,E是图G中边的有限集合。E(G)也可以为空集。若E(G)为空,则图G只有顶点而没有边。


其实,用句不是很严谨的话来说,图可以看成是没有任何限制的树(比如,可以有环状,可以有多种关系等等)。


❣️❣️顶点与边


图是由顶点集和边集组成。


图:一般使用G表示


顶点集:一般使用V表示,是一个有穷非空集合。由顶点组成,例如:u,v 等顶点。


边集:一般使用E表示,是一个有穷集合,可以是空集。由边组成,例如:e等边。


记作:G = (V, E)


零图:E可以是空集,此时图G只有顶点没有边,称为零图。


例如:


c4b8b20acbbe428ab062a89846aab35f.png


零图:

aa401a1e81b24fe997cc5bcffc448c2c.png


在图中,最基本的单元是顶点,相当于树中的节点,顶点之间的关联关系,被称为边。


还有一些图中,顶点之间的关联并不是完全对称的,举个例子比如说微博,你的粉丝列表里有我,但我的粉丝列表里未必有你,类似于这种单方面关注的,顶点之间的边就有了方向的区分,这种带有方向的图称为有向图。


827c8d85e6a3459f9d424ef345de6eb0.png


❣️❣️无向图


无向边:顶点u和顶点v,在没有方向的情况下形成的边,简称为边。


记作:(u, v) = (v, u),也就是 (u, v) 和 (v, u) 是等同的。


无向图(Undirected Graph):全部由无向边构成的图。


b244095a7e4b46fba13bed020848b142.png


❣️❣️有向图


有向边:按照方向,从顶点u到顶点v形成的边,简称为弧。


记作:<u, v>、<v, u> ,也就是<u, v> 和 <v, u> 是不同的。


顶点u称为 始点,或弧尾。


顶点v称为 终点,或弧头。


有向图(Directed Graph):全部由有向边构成的图。


01118cf7f7d24f5786f63cc6df0d9554.png


💚❤️💙💚❤❤️💙💚❤️❤💙💚❤️💙❤💚❤️💙💚❤❤️💙💚❤️❤💙❤️💙💚❤❤️❤💙


❣️❣️权和网


在一些图中,每一条边并不是完全等同的,使得边具有权重,涉及到权重的图,称为带权图 。


权重:与给定边之间的相关的成本。例如:航空公司航班图表,按城市之间的里程加权。


因此,综合有向无向、带权重不带权重,交叉来讲,图有带权重有向的、带权重无向的、不带权重的有向的、不带权重的无向的......


0f3a190312974d44aa09ec3586a238fa.png


在某些实际场景中,图中的每条边(或弧)会赋予一个实数来表示一定的含义,这种与边(或弧)相匹配的实数被称为"权",而带权的图通常称为网。如下图所示,就是一个网结构:


5f1f11c3c1474969913992627a87e0ef.png


权(Weight):在一个图中,每条边可以标上具有某种含义的数值,此数值称为该边上的权。


通常权是一个非负实数。


权可以表示从一个顶点到另一个顶点的距离、时间或代价等含义。


网(Network):边上标识权的图。


8d18019322f14465bd78843d14f8158f.png


❣️❣️完全图


在图论的数学领域,完全图是一个简单的无向图,其中每对不同的顶点之间都恰连有一条边相连。完整的有向图又是一个有向图,其中每对不同的顶点通过一对唯一的边缘(每个方向一个)连接。n个端点的完全图有n个端点以及n(n − 1) / 2条边,以Kn表示。它是(k − 1)-正则图。所有完全图都是它本身的团。


无向完全图:每两个顶点之间都存在一条边。无向完全图是用n表示图中顶点数目的一种完全图,该图中每条边都是无方向的。在无向图中,如果任意两个顶点之间都存在边,则称该图为 无向完全图。

9ed95cde5f04475a863d8d3257175e67.png


有向完全图:每两个顶点之间都存在着方向相反的两条边。有向完全图是指概述图中各边都有方向,且每两个顶点之间都有两条方向相反的边的连接图。

7318cf63428641c19a9a10d59c0a72b6.png


完全图有n个顶点,e条边,两者关系:

469a6812ac0144cfab0c06d7fb35b656.png


❣️❣️稠密图和稀疏图


稀疏图和稠密图:这两种图是相对存在的,即如果图中具有很少的边(或弧),此图就称为"稀疏图";反之,则称此图为"稠密图"。

稀疏和稠密的判断条件是:e<nlogn,其中 e 表示图中边(或弧)的数量,n 表示图中顶点的数量。如果式子成立,则为稀疏图;反之为稠密图。

3e5fd5d17c0d4776a4b60b659b3a3168.png


b201b5f0a4a04ce7ba5df300f972c01a.png


n为顶点数,e为边数,两图的相关计算如下:


852f1876db464436981942552a96e10f.png


❣️❣️子图和生成子图


所有的顶点和边都属于图G的图称为G的子图。含有G的所有顶点的子图称为G的生成子图。


子图(Subgraph)


设有两个图 G=(V, E) 和 G'=(V', E'),若V‘是V的子集,即V’ ∈ V,并且E‘ 是 E的子集,即E’ ∈ E,则称 G‘ 为G的子图,记为 G’ ∈ G。


生成子图(Spanning Subgraph)


若G‘ 为G的子图,并且V’ = V,则称G‘ 为G的生成子图,即包含原图中所有顶点的子图。


导出⼦图(Induced Subgraph)

定义:导出⼦图G’,V’∈V,但对于V’中任⼀顶点,只要在原图G中有对应边,那么就要出现在E’中。

5cab05482ecb49aeaec251e86f78a069.png


83ae540a3c4c4063ae04aa1af0375921.png


4d4fe2477a454393a485d4de20660c1c.png


💚❤️💙💚❤❤️💙💚❤️❤💙💚❤️💙❤💚❤️💙💚❤❤️💙💚❤️❤💙❤️💙💚❤


❣️❣️邻接点


假若顶点v 和顶点w 之间存在一条边, 则称顶点v 和w 互为邻接点。


在一个无向图中,若存在一条边(u,v),则称顶点u与v互为邻接点。


边(u,v)是顶点u和v关联的边


顶点u和v是边(u,v)关联的顶点。


例如:以顶点1为端点的3条边是(0,1),(1,2),(1,4),顶点1的3个邻接点分别为 0,2,4


82c7348849624cde8ffe965a986b451c.png


在一个有向图中,若存在一条弧<u,v>,则称顶点u邻接到v,顶点v邻接自u。


弧<u,v>和顶点u、v关联。


例如:顶点v0有2条出边<v0,v1>,<v0,v2>,1条入边<v3,v0>,顶点v0邻接到v1和v2,顶点v0邻接自v3


e4b3c374719443769726eae18861d28d.png


❣️❣️顶点的度


顶点的度(Degree):图中与该顶点相关联边的数目。顶点v的度记为 D(v)。


若一 个图有n个顶点和e条边,则该图所有顶点的度之和与边数满足如下关系:


0c546e1acb96426995a1a094f981c870.png


每条边关联两个顶点,对顶点的度贡献为2,所有全部顶点的度之和为所有边数的2倍。

无向图顶点的度:以该顶点为一个端点的边的数目 ,即该顶点的边的数目。

db3eabd7d50d4cea870c0a68372617f9.png

有向图顶点的度


入度(in degree):顶点v的入边数目,称为该顶点的入度,记为 ID(v)。


以v为终点的弧的数目称为入度。


出度(out degree):顶点v的出边数目,称为该顶点的出度,记为 OD(v)。


以v为起点的弧的数目称为出度。


顶点v的度:等于它的入度和出度之和。记作 D(v) = ID(v) + OD(v)


8ddebe98f18d43cdbe149bf5162f4de5.png


❣️❣️路径与回路


无论是无向图还是有向图,从一个顶点到另一顶点途径的所有顶点组成的序列(包含这两个顶点),称为一条路径。如果路径中第一个顶点和最后一个顶点相同,则此路径称为"回路"(或"环")。

并且,若路径中各顶点都不重复,此路径又被称为"简单路径";同样,若回路中的顶点互不重复,此回路被称为"简单回路"(或简单环)。


拿下图来说,从 V1 存在一条路径还可以回到 V1,此 路径为 {V1,V3,V4,V1},这是一个回路(环),而且还是一个简单回路(简单环)。

e60ae4de50f24c848e0b771cc46b968f.png


在有向图中,每条路径或回路都是有方向的。


路径(Path):在一个图中,路径是从顶点u到顶点v所经过的顶点序列。


u=v0,v1,...vm = v


路径长度:该路径上边的数目。


回路:第一个顶点和最后一个顶点相同的路径,称为回路或环。


初等路径:序列中顶点不重复出现的路径。


初等回路:除了 第一个顶点和最后一个顶点 之外,其余顶点不重复出现的回路。


实例1:


370cddff2bcd429fa30dedc40e9d896c.png


路 径 (v0, v2, v3, v1) 是初等路径,其路径长度为3。


路径 (v0, v2, v3, v0, v1) 不是初等路径,其路径长度为4。


路径 (v0, v2, v3, v0) 是初等回路,其路径长度为3。


网中的路径长度:在网中,从始点到终点的路径上各边的权值之和,称为路径长度


5207f6b555c94ac8858c8f8b0229ce0d.png


实例2:从顶点A到顶点E的一条路径


(A, B, D, E) --> 路径长度:10 + 7 + 2 = 19


❣️❣️💚❤️💙💚❤❤️💙💚❤️❤💙💚❤️💙❤💚❤️💙💚❤❤️💙💚❤️❤💙❤️💙💚❤


相关文章
|
2月前
|
算法 安全 网络安全
数据结构之网络攻击路径(深度优先搜索)
本文介绍了如何使用深度优先搜索(DFS)算法分析网络攻击路径。在网络安全领域,DFS用于检测网络中潜在的攻击路径,帮助安全人员及时发现并阻止威胁。文中详细描述了网络图的构建、节点间的连接关系以及DFS的实现过程。通过一个具体的例子,展示了如何检测从一个普通节点到关键节点的攻击路径,并讨论了DFS算法的优缺点。提供的C++代码实现了网络图的构建和攻击路径的检测功能。
71 24
|
2月前
|
算法 数据处理 C语言
C语言中的位运算技巧,涵盖基本概念、应用场景、实用技巧及示例代码,并讨论了位运算的性能优势及其与其他数据结构和算法的结合
本文深入解析了C语言中的位运算技巧,涵盖基本概念、应用场景、实用技巧及示例代码,并讨论了位运算的性能优势及其与其他数据结构和算法的结合,旨在帮助读者掌握这一高效的数据处理方法。
47 1
|
3月前
|
存储 算法
数据结构与算法学习二二:图的学习、图的概念、图的深度和广度优先遍历
这篇文章详细介绍了图的概念、表示方式以及深度优先遍历和广度优先遍历的算法实现。
72 1
数据结构与算法学习二二:图的学习、图的概念、图的深度和广度优先遍历
|
7月前
|
存储 算法 Linux
【数据结构和算法】---二叉树(1)--树概念及结构
【数据结构和算法】---二叉树(1)--树概念及结构
61 0
|
3月前
|
分布式计算 Hadoop Unix
Hadoop-28 ZooKeeper集群 ZNode简介概念和测试 数据结构与监听机制 持久性节点 持久顺序节点 事务ID Watcher机制
Hadoop-28 ZooKeeper集群 ZNode简介概念和测试 数据结构与监听机制 持久性节点 持久顺序节点 事务ID Watcher机制
55 1
|
3月前
【高阶数据结构】深度探索二叉树进阶:二叉搜索树概念及其高效实现(三)
【高阶数据结构】深度探索二叉树进阶:二叉搜索树概念及其高效实现
|
3月前
|
存储
【高阶数据结构】深度探索二叉树进阶:二叉搜索树概念及其高效实现(二)
【高阶数据结构】深度探索二叉树进阶:二叉搜索树概念及其高效实现
|
3月前
【高阶数据结构】深度探索二叉树进阶:二叉搜索树概念及其高效实现(一)
【高阶数据结构】深度探索二叉树进阶:二叉搜索树概念及其高效实现
|
3月前
|
存储 分布式计算 算法
大数据-105 Spark GraphX 基本概述 与 架构基础 概念详解 核心数据结构
大数据-105 Spark GraphX 基本概述 与 架构基础 概念详解 核心数据结构
62 0
|
4月前
|
C语言
数据结构基础详解(C语言):图的基本概念_无向图_有向图_子图_生成树_生成森林_完全图
本文介绍了图的基本概念,包括图的定义、无向图与有向图、简单图与多重图等,并解释了顶点度、路径、连通性等相关术语。此外还讨论了子图、生成树、带权图及几种特殊形态的图,如完全图和树等。通过这些概念,读者可以更好地理解图论的基础知识。
204 8