【数据结构】非线性数据结构——图

1. 图的定义

图(Graph) 是一种由一组 顶点(Vertex) 和一组 边(Edge) 构成的数据结构。图通常用来表示 实体(顶点) 之间的关系(边)。例如,社交网络中的用户和朋友关系、道路网络中的城市和道路、计算机网络中的设备和连接等,都是可以通过图来建模的。

2. 图的基本概念

3. 图的表示方式

图可以通过以下几种方式来表示:

1)邻接矩阵(Adjacency Matrix):

邻接矩阵是一个二维数组 A[i][j],用于表示顶点 𝑖 和顶点 𝑗 之间是否存在边。

优点:查找是否存在边的时间复杂度为 O(1)。

缺点:对于稀疏图(边远少于顶点数的图),会浪费大量空间。

2)邻接表(Adjacency List):

邻接表是为每个顶点维护一个链表或列表,列表中保存与该顶点相连的所有顶点。每个顶点都有一个链表,链表中的元素是与该顶点直接相连的其他顶点。

优点:节省空间,特别适用于稀疏图。对于每个顶点的所有邻居,可以快速访问。

缺点:查找是否存在一条特定边的时间复杂度是 O(k),其中 k 是该顶点的邻居数量。

3)边列表(Edge List):

边列表是一种简单的图表示方法,其中包含所有的边,每条边由一对顶点组成。通常用于表示无向图或有向图的边集合。

优点:简单易懂,适用于边的操作。

缺点:不适合高效地进行邻接查询。

3. 图的基本术语

4. 图的遍历

图的遍历是图论中的基本操作,主要有两种方式:

1)深度优先搜索(DFS, Depth-First Search):

DFS 是一种从起始顶点开始,沿着一个分支一路向下走,直到没有新的顶点可以访问,然后回溯到上一个分支,继续访问其他未访问的顶点,直到所有顶点都被访问过。递归 或 栈 可用于实现 DFS。

2) 广度优先搜索(BFS, Breadth-First Search):

BFS 是一种从起始顶点开始,首先访问所有相邻的顶点,然后再访问这些顶点的邻居,依此类推,直到所有顶点都被访问过。队列 是 BFS 的常用实现工具。

5. 图的应用场景

图在许多领域都有广泛的应用,包括但不限于:

  • 社交网络:在社交网络中,用户是图中的顶点,用户之间的好友关系是图中的边。图可以帮助发现群体、推荐朋友、分析社交影响等。

  • 计算机网络:计算机网络中的设备(如路由器、交换机)可以视为图中的顶点,设备之间的连接为图中的边。路由算法、网络拓扑分析等问题都可以通过图来建模。

  • 任务调度:任务调度中,任务可以视为顶点,任务之间的依赖关系可以表示为边。通过图的遍历和排序算法(如拓扑排序),可以有效地安排任务的执行顺序。

  • 网页链接分析:网页之间的链接关系是有向图。搜索引擎通过分析网页的链接结构来评估网页的排名(如 PageRank 算法)。

相关推荐
love666666shen1 小时前
【面试】后端开发面试中常见数据结构及应用场景、原理总结
数据结构·计算机网络·链表·操作系统··索引·后端开发
掐死你滴温柔3 小时前
SQLALchemy如何将SQL语句编译为特定数据库方言
数据结构·数据库·python·sql
秋风&萧瑟5 小时前
【数据结构】双向循环链表的使用
数据结构·windows·链表
HUT_Tyne2658 小时前
力扣--LCR 167.招式拆解I
数据结构·算法·leetcode
~糖炒栗子~9 小时前
[Day 11]209.长度最小的子数组
数据结构·c++·算法·leetcode
L73S379 小时前
数据结构、算法与STL
数据结构·笔记·程序人生·算法
zym大哥大10 小时前
C++11右值与列表初始化
数据结构·c++
qystca10 小时前
洛谷 P1075 [NOIP2012 普及组] 质因数分解 C语言
c语言·数据结构·算法
程序员shen16161110 小时前
短视频矩阵源码开发/saas矩阵部署/api矩阵源码接口搭建
数据结构·数据库·python·线性代数·算法·矩阵
我要学编程(ಥ_ಥ)12 小时前
数据结构理论篇(期末突击)
数据结构