问题引入
有一天,你穿越到Clannad(炒鸡好看的游戏与番剧)的小镇。你知道小镇上的每个地方与每条路。小镇的某些地方可能会藏有实现愿望的光玉。现在你要出发去收集小镇上所有的光玉。
如图:
假设小镇中一个地方对应这张图的一个结点,你的出生点在古河面包店(0号位置),据题意,你需要一个地点都不落地走完整张图,这样才能收集完所有光玉。
BFS
广度优先搜索(Breadth First Search):
属于一层一层地扩展,每次到一个点后,把这个点其他相邻点都记录下来,作为下一层的待访问结点。
根据这个概念,我们需要准备:
一个小本本
步骤:
1、每到达一个点(最开始是起点),观望一下周围哪些地点跟当前点相连,把这些点都添加在小本本上。
2、跳到小本本上记录的第一个地点(执行 1 步骤),然后把这个地点从小本本上擦除。
3、重复执行 2、直到小本本上没有记录任何点(此时已经到达了所有地点,后面有实例将证明)
根据上面的步骤,可以给出伪代码:
<