算法 | 广度优先遍历BFS

栏目: 编程工具 · 发布时间: 6年前

内容简介:本文首发于微信公众号:"算法与编程之美",欢迎关注,及时了解更多此系列文章。问题描述

欢迎点击「算法与编程之美」↑关注我们!

本文首发于微信公众号:"算法与编程之美",欢迎关注,及时了解更多此系列文章。

问题描述

BFS算法,也称作广度优先搜索算法。是一种图形搜索演算法。简单的说,BFS是从根节点开始,沿着树的宽度遍历树的节点,如果发现目标,则演算终止。(百度百科)

举例分析:

先用一个树结构来说明bfs算法的搜索规律

算法 | 广度优先遍历BFS

如果上图要用bfs算法的话。它会从左至右遍历每层节点

遍历过程:A B C D E F G H I

实例练习

那如果是一个图呢?一样的原理,只是图没有根节点,所以我们要选取一个点来作根节点

以下图为例,我们以A做根节点,A的下一层为B C,假设距离为1,则距离A为2的作为下一层节点也就是D E,同理再下一层为F。则顺序为ABCDEF

算法 | 广度优先遍历BFS

接下来就是代码实现了:

因为BFS算法是一层一层的遍历,所以我们可以用一个队列来储存,接下来讲为什么

队列是先进先出的结构,我们可以先将一个起始节点塞入队列,然后每次拿出一个节点,并将它的邻接点塞入。

假设我们先塞入A,将其取出后塞入A的邻接点BC,接着取出B塞入B的邻接点D,依此类推。这样做可以保证层的队列顺序,比如这个队列的存入顺序就是ABCDEF

代码我们分三步写:输入,算法设计,输出

第一步输入:

因为我们需要记录的每一个节点以及与其相连的节点,所以可以用字典来存入

算法 | 广度优先遍历BFS

第二步算法设计:

我们需要用到的数据有两个,一个是地图数据,一个是根节点(也可以说是起点)

具体思路在代码旁作注释表达

算法 | 广度优先遍历BFS

第三步输出:

假设起始点也就是根节点是E,距离E一距离的是CD,相距二距离的是ABF

算法 | 广度优先遍历BFS

将起始点设为A来看看

算法 | 广度优先遍历BFS

符合BFS算法的遍历顺序。

结语

学习算法时,很容易存在逻辑不理解的地方,只要多练多看,一定会可以理解的。BFS算法不仅可以用来遍历,还可以用来获取路径,比如从A到F的最短路径,只需要在源代码的基础上略做修改,小伙伴们可以动动脑筋,自己下来试试哦。若有疑问,可在评论区留言。

where2 go 团队

   

微信号:算法与编程之美          

算法 | 广度优先遍历BFS

长按识别二维码关注我们!

温馨提示: 点击页面右下角 “写留言”发表评论,期待您的参与!期待您的转发!


以上所述就是小编给大家介绍的《算法 | 广度优先遍历BFS》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

创投42章经

创投42章经

曲凯 / 中信出版集团 / 2018-10-20 / 58.00

《创投42章经》是拥有百万粉丝的微信公众号“42章经”的精选文章合集,全书共分为心法、内功、招式和江湖传奇四部分。 在心法部分,读者可以学到一些创业与投资的底层思维方式;在内功部分,读者可以了解到,投资人看待一家公司经营状况的标准;在招式部分,读者可以看到作者作为一名资深投资人和睿智的观察者,对过去几年主要的公司、模式以及风口的判断;最后的江湖传奇部分,作者通过一些故事,帮助读者更好地理解当......一起来看看 《创投42章经》 这本书的介绍吧!

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具

html转js在线工具
html转js在线工具

html转js在线工具

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具