图的遍历——BFS 与 DFS 深度优先和广度优先搜索|图论算法

问题引入

有一天,你穿越到Clannad(炒鸡好看的游戏与番剧)的小镇。你知道小镇上的每个地方与每条路。小镇的某些地方可能会藏有实现愿望的光玉。现在你要出发去收集小镇上所有的光玉。

如图:

假设小镇中一个地方对应这张图的一个结点,你的出生点在古河面包店(0号位置),据题意,你需要一个地点都不落地走完整张图,这样才能收集完所有光玉。

BFS

广度优先搜索(Breadth First Search):

属于一层一层地扩展,每次到一个点后,把这个点其他相邻点都记录下来,作为下一层的待访问结点。

根据这个概念,我们需要准备:

一个小本本

步骤:

1、每到达一个点(最开始是起点),观望一下周围哪些地点跟当前点相连,把这些点都添加在小本本上。

2、跳到小本本上记录的第一个地点(执行 1 步骤),然后把这个地点从小本本上擦除。

3、重复执行 2、直到小本本上没有记录任何点(此时已经到达了所有地点,后面有实例将证明)

根据上面的步骤,可以给出伪代码:

<
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值