数据结构之图:无向图的介绍与功能实现,Python——22

本文深入探讨无向图的概念,解析其在数据结构中的角色及应用,对比无向图与有向图的区别,阐述图的存储结构如邻接矩阵与邻接表,并提供Python代码实现,适合初学者和进阶学习者。

无向图(Undigraph)的介绍

引入

  • 生活中的图,有地图,集成电路板的图,可以看类似的看做是数据结构中的图
  • 数据有"一对一",“一对多”和“多对多”的关系,前两种分别表示线性表和树的存储结构性质,而多对多则可表示图的存储结构性质

定义

  • 图是由有限的(并且可能是可变的)组的顶点(vertices,或称点points,结点nodes),以及一系列由这些每两个顶点之间相连的有向或无向的边(edges,或称链接links,线lines),组合而成的一种数据结构

图的分类
按照连接两个顶点的边的不同,可以把图分为以下两种:

  • 无向图:边仅仅连接两个顶点,没有其他含义;
  • 有向图:边不仅连接两个顶点,并且具有方向;

图中的术语

  • 和相邻顶点: 当两个顶点通过一边相连时,我们称这两个顶点是相邻的,并且称这条边依附于这两个顶点。
  • 度:某个顶点的度就是依附于该顶点的边的个数
  • 子图:是一幅图中由一部分的边及其连接的顶点的组成的子集;
  • 路径:由边顺序连接的一系列的顶点组成
  • 环:是一条至少含有一条边且终点和起点相同的路径(示例图中的红色环)
  • 连通图:如果图中任意一个顶点都存在一条路径到达另外一 个顶点,那么这幅图就称之为连通图
  • 连通子图:一个非连通图由若干连通的部分组成,每一个连通的部分 都可以称为该图的连通子图
    在这里插入图片描述
    在这里插入图片描述

无向图

图的存储结构
要表示一幅图,只需要表示清楚以下两部分内容即可:

  1. 图中所有的顶点;
  2. 所有连接顶点的边;

常见的图的存储结构有两种:邻接矩阵和邻接表
邻接矩阵
3. 使用一个V*V的二维数组int[V][V] adj,把索引的值看做是顶点; .
4. 如果顶点v和顶点w相连,我们只需要将adj[v][w]和adj[w][v]的值设置为1,否则设置为0即可。
在这里插入图片描述
解释:
使用二维数组表示一个图,二维数组有两个维度的索引,这两套索引都表示图的顶点,当我们要查看两个顶点之间是否相连通时,例如查看顶点A是否连通顶点B(存在方向A→B),我们就查看这两个顶点一维索引A和二维索引B对应的值即可,这里我们定义如果值为1就表示连通,如果为0则表示不连通。
很明显,邻接矩阵这种存储方式的空间复杂度是V^2的,如果我们处理的问题规模比较大的话,内存空间极有可能不够用。

邻接表

  1. 使用一个大小为V的数组Queue[V] adj ,把索弓|看做是顶点; .
  2. 每个索|处adj[V]存储了一个队列,该队列中存储的是所有与该顶点相邻的其他顶点储存相连的顶点的数据结构是队列,有序的
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值