购买
下载掌阅APP,畅读海量书库
立即打开
畅读海量书库
扫码下载掌阅APP

1.3 图的遍历

图的遍历 (Traversing Graph)是指从图中某一顶点出发,按照某种遍历方法访问图中的全部顶点,且每个顶点仅被访问一次。图的遍历是很多图算法的基础。本节介绍两种主要的遍历方法: 广度优先搜索 深度优先搜索 。这两种遍历方式对无向图和有向图都适用。

1.3.1 广度优先搜索

假设初始时,图 G 的所有顶点均未被访问过,在图 G 中任选一个顶点 v i 作为起始点,则广度优先搜索(Breadth-First Search,BFS)的基本思想是:

①首先访问起始顶点 v i ,接着由 v i 出发,依次访问 v i 的各个未访问过的邻接顶点 w 1 w 2 ,…, w i

②然后依次访问 w 1 w 2 ,…, w i 的所有未被访问过的邻接顶点;

③以此类推,直至图中所有已被访问的顶点的邻接点都被访问到;

④若此时图中尚有顶点未被访问,则另选图中一个未曾被访问的顶点作为起始点,重复上述过程,直到图中所有顶点都被访问到为止。

实际上,广度优先搜索遍历图的过程是以 v 为起始点,由近至远依次访问和 v 有路径相通且路径长度为1,2,…的顶点。

对如图1-20所示的无向图 G 7 ,从顶点 v 1 出发的广度优先搜索的过程为:首先访问顶点 v 1 ,然后访问与它相邻接的顶点 v 2 v 3 v 4 ,接着再依次访问这三个顶点的邻接点中未访问的顶点 v 5 v 6 ,最终得到顶点被访问的顺序是 v 1 v 2 v 3 v 4 v 5 v 6

图1-20 无向图 G 7

1.3.2 深度优先搜索

假设初始时,图 G 的所有顶点均未被访问过,在图 G 中任选一个顶点 v i 作为起始点,则深度优先搜索(Depth-First Search,DFS)的基本思想是:

①首先访问起始顶点 v i

②然后从 v i 的未被访问的邻接点中依次选择顶点 w ,若 w 未曾被访问,则以 w 为新的起始点继续进行深度优先搜索,以此类推,直到图中与 v i 有路径相通的顶点全部被访问到;

③若此时图中尚有顶点未被访问,则另选图中一个未被访问的顶点作为始点,重复①和②,直至图中所有顶点都被访问到为止。

以如图1-20所示的无向图 G 7 为例说明深度优先搜索的过程:从顶点 v 1 出发,访问完 v 1 之后,选择邻接顶点 v 2 ,访问完 v 2 之后,退回到 v 1 ,选择 v 1 的下一个邻接顶点 v 3 。因为 v 3 未被访问,所以可以从 v 3 出发进行深度优先搜索,首先选择 v 3 的一个邻接顶点 v 5 ,访问完 v 5 之后,退回到 v 3 ,访问其另一个邻接顶点 v 6 ,之后退回到 v 1 ,访问 v 1 的最后一个邻接顶点 v 4 。由此得到的顶点访问序列为 v 1 v 2 v 3 v 5 v 6 v 4 WFQasEt3Kmd1/BhU7j+vJH8LtObvrwQ4m+LJql4m7l25l0N3iyilPcxoHBkxK9Nl

点击中间区域
呼出菜单
上一章
目录
下一章
×