深入解析BFS算法原理,带图解说明,并附带Python代码实现BFS算法

PHPz
发布: 2024-01-22 23:24:05
转载
2346人浏览过

bfs又名广度优先搜索,和dfs算法一样都是递归算法,不同的是,bfs算法通过队列,在避免循环的同时遍历目标所有节点。

BFS算法的工作原理图解

以具有5个节点的无向图为例,如下图:

BFS算法概念原理详细图解 Python代码实现BFS算法

从节点0开始,BFS算法首先将其放入Visited列表并将其所有相邻节点放入队列。

立即学习Python免费学习笔记(深入)”;

BFS算法概念原理详细图解 Python代码实现BFS算法

接下来,访问队列前面的节点1,并转到节点1相邻的节点。因为节点0已经被访问过,所以访问节点2。

BFS算法概念原理详细图解 Python代码实现BFS算法

节点2有一个未访问的相邻节点4,但因为节点4在队列的最后,因此我们要先访问位于队列前面的节点3。

BFS算法概念原理详细图解 Python代码实现BFS算法

队列中只剩下节点4没有被访问,所以最后访问节点4。

BFS算法概念原理详细图解 Python代码实现BFS算法

至此,已经完成了此无向图的广度优先遍历。

BFS算法的伪代码

create a queue Q 
mark v as visited and put v into Q 
while Q is non-empty 
remove the head u of Q 
mark and enqueue all (unvisited) neighbours of u
登录后复制

Python代码实现BFS算法

import collections
def bfs(graph, root):
    visited, queue = set(), collections.deque([root])
    visited.add(root)

while queue:
        vertex = queue.popleft()
        print(str(vertex) + " ", end="")

        for neighbour in graph[vertex]:
            if neighbour not in visited:
                visited.add(neighbour)
                queue.append(neighbour)

if __name__ == '__main__':
    graph = {0: [1, 2], 1: [2], 2: [3], 3: [1, 2]}
    print("Following is Breadth First Traversal: ")
    bfs(graph, 0)
登录后复制

以上就是深入解析BFS算法原理,带图解说明,并附带Python代码实现BFS算法的详细内容,更多请关注php中文网其它相关文章!

python速学教程(入门到精通)
python速学教程(入门到精通)

python怎么学习?python怎么入门?python在哪学?python怎么学才快?不用担心,这里为大家提供了python速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
相关标签:
来源:网易伏羲网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号