DFS与BFS算法讲解

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(该节点)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值