算法学习笔记:深度优先搜索(DFS)
一、深度优先搜索
深度优先搜索属于图算法的一种,是一个针对图和树的遍历算法,英文缩写为DFS即Depth First Search。深度优先搜索是图论中的经典算法,利用深度优先搜索算法可以产生目标图的相应拓扑排序表,利用拓扑排序表可以方便的解决很多相关的图论问题,如最大路径问题等等。一般用栈数据结构来辅助实现DFS算法。其过程简要来说是对每一个可能的分支路径深入到不能再深入为止,而且每个节点只能访问一次。
基本思想:
(1)访问顶点v;
(2)从v的未被访问的邻接点中选取一个顶点w,从w出发进行深度优先遍历;
(3)重复上述两步,直至图中所有和v有路径相通的顶点都被访问到。
算法复杂度:
若有v个顶点、E条边,则
用邻接表储存图,有O(V+E)
用邻接矩阵储存图,有O(V^2)
//递归
void DFS(Vetex v)
{
Visited[v] = true;
for each w adjacent to v
if (!Visited[w])
DFS(w);
}
//非递归
void DFS(Vertex v)
{
Visited[v] = true;
Stack sta = MakeStack(MAX_SIZE);
Push(sta, v);
while (!Empty(sta))
{
Vertex w = Pop(sta);
for each u adjacent to w
{
if (!Visited[u])
{
Push(sta, u);
Visited[u] = true;
}
}
}
}