数据结构速成--图

由于是速成专题,因此内容不会十分全面,只会涵盖考试重点,各学校课程要求不同 ,大家可以按照考纲复习,不全面的内容,可以看一下小编主页数据结构初阶的内容,找到对应专题详细学习一下。

目录

一、图的基本结构

二、图的存储结构

三、图的遍历

[1. 广度优先遍历(BFS)](#1. 广度优先遍历(BFS))

[2. 深度优先遍历(DFS)](#2. 深度优先遍历(DFS))

[3. 总结](#3. 总结)

四、最小生成树

五、拓扑排序

六、关键路径


一、图的基本结构

二、图的存储结构

三、图的遍历

1. 广度优先遍历(BFS)

广度优先搜索类似于二叉树的层序遍历 算法。一般用队列实现。

2. 深度优先遍历(DFS)

深度优先搜索类似于树的先序遍历 。常用来实现。

3. 总结

BFS就是一口气把和顶点相连的所有顶点遍历,从遍历结果的第二个顶点继续把和第二个顶点相连的所有未遍历的顶点输出。

DFS是先遍历和顶点相连的一个顶点,再从这个顶点出发找一个相连的顶点,重读步骤,如果当前顶点和他相连的所有顶点都遍历过了,就看前面的顶点他相连的有没有没遍历的。

因此我们也可以根据邻接表/邻接矩阵写出BFS或DFS遍历序列。

四、最小生成树

五、最短路径

顶点到自身的距离为0,每加入一个最短的路径,就要看该顶点到其他顶点的最短路径有没有发生改变。

五、拓扑排序

拓扑排序可以用来判断是否存在回路/环。

六、关键路径

从开始顶点到结束顶点的所有路径中,具有最大路径长度的路径称为关键路径。

关键路径上的所有活动都是关键活动,因此可以加快关键活动来缩短整个工程的工期

网中的关键路径并不唯一 ,且对于有几条关键路径的网,只提高一条关键路径上的关键活动并不能缩短整个工程的工期,只有加快那些包括在所有关键路径上的关键活动才能达到缩短工期的目的

注意:ve(i)找最大的,vl(i)找最小的。

d(i)=0即为关键路径。

相关推荐
驭渊的小故事22 分钟前
简单模板笔记
数据结构·笔记·算法
VT.馒头44 分钟前
【力扣】2727. 判断对象是否为空
javascript·数据结构·算法·leetcode·职场和发展
历程里程碑2 小时前
Linux 库
java·linux·运维·服务器·数据结构·c++·算法
Sheep Shaun2 小时前
如何让一个进程诞生、工作、终止并等待回收?——探索Linux进程控制与Shell的诞生
linux·服务器·数据结构·c++·算法·shell·进程控制
Pluchon2 小时前
硅基计划4.0 简单模拟实现AVL树&红黑树
java·数据结构·算法
小龙报3 小时前
【51单片机】从 0 到 1 玩转 51 蜂鸣器:分清有源无源,轻松驱动它奏响新年旋律
c语言·数据结构·c++·stm32·单片机·嵌入式硬件·51单片机
dllxhcjla3 小时前
数据结构和算法
数据结构
历程里程碑4 小时前
普通数组----轮转数组
java·数据结构·c++·算法·spring·leetcode·eclipse
sin_hielo4 小时前
leetcode 1653
数据结构·算法·leetcode
李日灐4 小时前
C++进阶必备:红黑树从 0 到 1: 手撕底层,带你搞懂平衡二叉树的平衡逻辑与黑高检验
开发语言·数据结构·c++·后端·面试·红黑树·自平衡二叉搜索树