![](https://img-blog.csdnimg.cn/direct/b4088d5b749d40dd99505a319ef8116b.png)
由于是速成专题,因此内容不会十分全面,只会涵盖考试重点,各学校课程要求不同 ,大家可以按照考纲复习,不全面的内容,可以看一下小编主页数据结构初阶的内容,找到对应专题详细学习一下。
目录
[1. 广度优先遍历(BFS)](#1. 广度优先遍历(BFS))
[2. 深度优先遍历(DFS)](#2. 深度优先遍历(DFS))
[3. 总结](#3. 总结)
一、图的基本结构
![](https://img-blog.csdnimg.cn/direct/60ccb955411d4919be852a79389470bd.png)
![](https://img-blog.csdnimg.cn/direct/c6dd8ca31eff4deba0ceb4cd199a6e13.png)
二、图的存储结构
![](https://img-blog.csdnimg.cn/direct/87a8510e48074e0b8706e927f9ecd450.png)
![](https://img-blog.csdnimg.cn/direct/c9090b2779c5464eb0de9068db0e85bc.png)
![](https://img-blog.csdnimg.cn/direct/cf0a006f120941b5bd3a17a5c06047e4.png)
![](https://img-blog.csdnimg.cn/direct/20bbc18ff49741ac9627bc3840363871.png)
![](https://img-blog.csdnimg.cn/direct/dbd91e7fbefa4f90b96b157594788434.png)
三、图的遍历
1. 广度优先遍历(BFS)
广度优先搜索类似于二叉树的层序遍历 算法。一般用队列实现。
![](https://img-blog.csdnimg.cn/direct/1eb66aaf3e964962b80965fdf9456481.png)
2. 深度优先遍历(DFS)
深度优先搜索类似于树的先序遍历 。常用栈来实现。
![](https://img-blog.csdnimg.cn/direct/b7f214ad663e46b4a401ba4d00aa3d52.png)
3. 总结
BFS就是一口气把和顶点相连的所有顶点遍历,从遍历结果的第二个顶点继续把和第二个顶点相连的所有未遍历的顶点输出。
DFS是先遍历和顶点相连的一个顶点,再从这个顶点出发找一个相连的顶点,重读步骤,如果当前顶点和他相连的所有顶点都遍历过了,就看前面的顶点他相连的有没有没遍历的。
因此我们也可以根据邻接表/邻接矩阵写出BFS或DFS遍历序列。
四、最小生成树
![](https://img-blog.csdnimg.cn/direct/25d22c4298c44b968f94e8d6fed26eeb.png)
![](https://img-blog.csdnimg.cn/direct/11282d8db87943c4b7ff81c153ec2d7a.png)
![](https://img-blog.csdnimg.cn/direct/4cfc506b9a9544f4a5d1c35b1c9de522.png)
![](https://img-blog.csdnimg.cn/direct/7ffb6afd30ec43c6bbb1e834d718c06a.png)
五、最短路径
顶点到自身的距离为0,每加入一个最短的路径,就要看该顶点到其他顶点的最短路径有没有发生改变。
![](https://img-blog.csdnimg.cn/direct/bf270338d61848f2bca0e2544bf7ff4b.png)
![](https://img-blog.csdnimg.cn/direct/6177e2c38015434390696797504f46de.png)
五、拓扑排序
拓扑排序可以用来判断是否存在回路/环。
![](https://img-blog.csdnimg.cn/direct/997bfd9b79a74e1e8508d40fb5690ff5.png)
![](https://img-blog.csdnimg.cn/direct/68bb2f040e2644d0b0891c5feda1f720.png)
六、关键路径
从开始顶点到结束顶点的所有路径中,具有最大路径长度的路径称为关键路径。
![](https://img-blog.csdnimg.cn/direct/eef2e186c3fd417f9a9b180b3d8424b6.png)
关键路径上的所有活动都是关键活动,因此可以加快关键活动来缩短整个工程的工期 。
网中的关键路径并不唯一 ,且对于有几条关键路径的网,只提高一条关键路径上的关键活动并不能缩短整个工程的工期,只有加快那些包括在所有关键路径上的关键活动才能达到缩短工期的目的。
![](https://img-blog.csdnimg.cn/direct/f24aac8e430c4f20a967df53505b198e.png)
![](https://img-blog.csdnimg.cn/direct/b8804b89f8df4089a133b833619b2dd3.png)
注意:ve(i)找最大的,vl(i)找最小的。
![](https://img-blog.csdnimg.cn/direct/74f2f86508044c63912afc2c8d00e4a6.png)
d(i)=0即为关键路径。