BFS 题目解题套路

18 篇文章 3 订阅

BFS 基本套路

使用 BFS 解决题目的基本套路如下:

1、有一个数据结构描述起点和终点。

2、有一个数据结构描述题目相关数据。比如走迷宫类型题目,需要迷宫长、宽、迷宫内容。

3、一个队列 q,保存下一步访问的节点。

4、一个访问属性,用于控制重复访问。

5、一个距离属性,用于表示本节点距离起点的长度。

6、一个访问策略。也就是如何从当前节点走到下一个节点。这是 BFS 中最难的。

7、将起点加入到队列 q 中。

8、只要队列 q 不为空,则弹出队首元素,判断该元素是否为终点;如果是终点,结束;如果不是终点,开始访问策略,将下一个可能的节点推入到队列 q 中,并更新路径访问属性和距离属性。

9、如果队列为空,结束循环,说明没有找到答案。

P.S.

个人建议将这些相关属性放在一个结构体内,这样的优点是提高程序的可读性。

BFS 变种

有些走迷宫题目会出现杀死某人需要付出一定的代价。这样就会有状态变化,那么导致 BFS 的 vis 状态更复杂。如鸣人和佐助这题。那么解决方法就是增加 vis 的层数。比如一般迷宫是 M*N,对应的 bool vis[MAXM][MAXN]。由于增加了状态,我们就将 vis 变为三维数组,即第三维表示状态变化,如 bool vis[MAXM][MAXN][MAXT]。这样大大增强了算法的复杂度,一般为了降低算法复杂度,需要引入剪枝技巧。该技巧将在以后介绍。

参考题解

具体的 BFS 题目题解可以参考如下几个:

仙岛求药,https://blog.csdn.net/justidle/article/details/104651311

拯救行动,https://blog.csdn.net/justidle/article/details/104662118

鸣人和佐助,https://blog.csdn.net/justidle/article/details/104662604

单词序列,https://blog.csdn.net/justidle/article/details/104682089

  • 7
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

努力的老周

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值