DFS
深度优先遍历简称DFS,是针对图和树的遍历算法。利用深度优先算法可以产生目标图的相应拓扑排序表,利用拓扑排序表可以方便的解决很多相关的图论问题,比如最大路径问题等。
一般用堆或栈来实现。
过程:对每一个可能的分支路径深入到不能再深入为止,如果遇到死路就往回走,往回走的过程中遇到没访问过的节点就进入该节点继续深入,每个节点只能访问一次。
应用:先序遍历、中序遍历、后序遍历
模型:
void dfs(int step){
判断边界
尝试每一种可能 for(i=1;i<=n;i++){
继续下一步 dfs(step+1)
}
返回
}
BFS
广度优先遍历简称BFS,是连通图的一种遍历算法。Dijkstra单源最短路径算法和Prim最小生成树算法都采用了和广度优先遍历类似的思想。
一般用队列来实现。
过程:从根结点开始,沿着树/图的宽度遍历树/图的节点,如果所有的节点都被访问,那么算法终止。
应用:层序遍历、最短路径、求二叉树的最大高度、由点到面遍历图、拓扑排序
代码实现:
while queue 不空:
cur = queue.pop()
for 节点 in cur的所有相邻节点:
if 该节点有效且未访问过:
queue.push(该节点)