data:image/s3,"s3://crabby-images/11281/112814abff7018521b5487fb973a9571e5f79ac3" alt=""
树的深度优先遍历
树的深度优先遍历分为先根遍历和后根遍历。
图的深度优先遍历
data:image/s3,"s3://crabby-images/6daee/6daeee220a7a8542aac75496e345b12675861ad8" alt=""
代码(只能遍历连通图)
cpp
//深度优先遍历
void DFS(Graph G, int v) {//从顶点v出发,深度优先遍历图G
visit(v);//访问初始顶点v
visited[v] = true;//对v做已访问标记
for (w = FirsitNeighbor(G, v); w >= 0; w = NextNeighbor(G, v, w);)
//检查v所有邻接点
if (!visited[w]) {//w为v的尚未访问的邻接点
DFS(G, w);
}
}
DFS算法(Final版)
data:image/s3,"s3://crabby-images/96c09/96c099cec7d2ddf927f8bcba6294ec203581a0b9" alt=""
代码
cs
void DFSTraverse(Graph G) {//对图G进行深度优先遍历
for (int v = 0; v < G.vexnum; ++v)
visited[v] = false;//访问标记数组初始化
for (int v = 0; v < G.vexnum; ++v)//从0号顶点开始遍历
if (!visited[v])//对每个连通分量调用一次BFS
DFS(G, v);//vi未访问过,从vi开始BFS
}
//深度优先遍历
void DFS(Graph G, int v) {//从顶点v出发,深度优先遍历图G
visit(v);//访问初始顶点v
visited[v] = true;//对v做已访问标记
for (w = FirsitNeighbor(G, v); w >= 0; w = NextNeighbor(G, v, w);)
//检查v所有邻接点
if (!visited[w]) {//w为v的尚未访问的邻接点
DFS(G, w);
}
}
复杂度分析
空间复杂度
data:image/s3,"s3://crabby-images/0010e/0010e957e144769893cfab302cdd12943cdfe067" alt=""
时间复杂度
data:image/s3,"s3://crabby-images/1683e/1683e4e8cd1bd8787d711814256110248215e50d" alt=""
深度优先遍历练习
data:image/s3,"s3://crabby-images/309ff/309ffebea62044d9d97c5f965b320f7fc3fbb053" alt=""
data:image/s3,"s3://crabby-images/c28c8/c28c8427011c9b1fad05e4c382e07db28c7afbed" alt=""
data:image/s3,"s3://crabby-images/e8494/e84944459994f9744d898eb799035fa439b3d184" alt=""
深度优先生成树
data:image/s3,"s3://crabby-images/080e5/080e563dcf5e16c004fe8a107804e2055e2ceefe" alt=""
data:image/s3,"s3://crabby-images/64792/64792f0468e4d53bfbfef3af7d1ac1ab2c54c8fe" alt=""
深度优先生成森林
data:image/s3,"s3://crabby-images/b924a/b924ad86db3572294901bc16e7ea11467ade5fe8" alt=""
data:image/s3,"s3://crabby-images/39798/397981c3a110153b1ae6b2376ca6de9174750ca0" alt=""
图的遍历和图的连通性
无向图
data:image/s3,"s3://crabby-images/a76c3/a76c33496bf327b36c82be00235fc680662dd152" alt=""
有向图
data:image/s3,"s3://crabby-images/4da6d/4da6d30b814c0d86e26b54e7580c7e55c32388eb" alt=""
总结:
data:image/s3,"s3://crabby-images/dcd2b/dcd2bec9d4f43727b31c872d3e5f1234256f89d4" alt=""