广度优先搜索专题(bfs)

本文深入探讨了BFS(广度优先搜索)算法,包括其基本原理和使用队列进行层次遍历的方法。通过一个模板展示了BFS的实现过程,并强调了在访问和入队节点时的注意事项。此外,列举了多个BFS在实际问题中的应用,如矩阵块计数、迷宫求解等。最后,推荐了几道相关练习题供读者实战练习。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

⭐个人主页:一只快乐的猪猪🐷
🌙写作风格:简洁明了,只写干货🍚
✍写作领域:蓝桥,力扣,刷题技巧 👌
😍支持猪猪:点赞+收藏+关注😝

BFS

1、按照层次顺序一层一层的往下搜索(不过通常不用搜索完所有的情况就可以得到答案)
2、层次遍历需要用到队列
模板:

void BFS(int s)
{
    Deque<Integer> que=new LinkedList<>();
    que.offer(s);
    while(!q.empty())
    {
        1、取出队首元素top;
        2、访问队首元素top;
        3、将队首元素出队;
        4、将top的下一层结点中未曾访问的结点全部入队,并设置为已范访问;
    } 
}

⭐⭐第二步的访问队首元素可以是很多复杂的操作,针对具体问题而不同
⭐⭐第四步需要一个visted数组来标识某节点是否已经访问

BFS有很多应用,比如遍历二叉树,遍历图,寻找迷宫的最优路径,甚至还有一些比较抽象的问题,下面就进行刷题实战吧

相关题目

1、寻找矩阵中“块“的个数(BFS)
2、蓝桥杯2019年真题演练——4、 迷宫(JavaA组)
3、蓝桥杯2017年第八届真题-青蛙跳杯子
4、蓝桥杯2020年真题演练——4、七段码(JavaA组)


如果这篇文章对小伙伴们有帮助的话,希望点赞支持以下~ 谢谢喽!
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值