深度优先搜索
标签: 数据结构
学习人数: 4454


全屏播放
赞赏支持

深度优先遍历(Depth First Search)的主要思想是:

1、首先以一个未被访问过的顶点作为起始顶点,沿当前顶点的边走到未访问过的顶点;

2、当没有未访问过的顶点时,则回到上一个顶点,继续试探别的顶点,直至所有的顶点都被访问过。

在此我想用一句话来形容 “不撞南墙不回头”。

 

无向图的深度优先遍历图解
以下"无向图"为例:

对上无向图进行深度优先遍历,从A开始:

第1步:访问A。

第2步:访问B(A的邻接点)。 在第1步访问A之后,接下来应该访问的是A的邻接点,即"B,D,F"中的一个。但在本文的实现中,顶点ABCDEFGH是按照顺序存储,B在"D和F"的前面,因此,先访问B。

第3步:访问G(B的邻接点)。 和B相连只有"G"(A已经访问过了)  

第4步:访问E(G的邻接点)。 在第3步访问了B的邻接点G之后,接下来应该访问G的邻接点,即"E和H&qu...

登录查看完整内容


课后作业

课后习题

 

【2016年真题】下列选项中,不是下图深度优先搜索序列的是()

A.V1,V5,V4,V3,V2        B.V1,V3,V2,V5,V4
C.V1,V2,V5,V4,V3        D.V1,V2,V3,V4,V5

参考答案:D

 

【2015年真题】设有向图 G=(V,E),顶点集 V={V0,V1,V2,V3},边集 E={<v0,v1>,<v0,v2>,<v0,v3>,<v1,v3>}。若从顶点 V0 开始对图进行深度优先遍历,则可能得到的不同遍历序列个数是()。
A.2    B.3    C.4    D.5

参考答案:D


登录后发布评论

暂无评论,来抢沙发