广度优先搜索(BFS, Breadth-First Search)

好的,我给你讲 广度优先搜索(BFS, Breadth-First Search),并配一个直观例子。


1️⃣ 什么是广度优先

广度优先搜索的特点:

  1. 按层访问:先访问根节点,然后访问它的直接子节点,再访问子节点的子节点......

  2. 使用队列(FIFO):保证先入队的节点先访问。

  3. 常用于:层序遍历二叉树、最短路径搜索、图的遍历等。

核心思想:先访问"广度"(当前层)再访问"深度"(下一层)。


2️⃣ 举例:二叉树层序遍历

假设有二叉树:

复制代码
        1
       / \
      2   3
     / \   \
    4   5   6

用列表表示为:

复制代码
[1, 2, 3, 4, 5, None, 6]

BFS 遍历过程

  1. 初始队列

    queue = [1]

  • 访问 1,加入结果 [1]

  • 将左右子节点 23 入队

    queue = [2, 3]

  1. 访问第二层
  • 访问 2 → 结果 [2],入队 45

  • 访问 3 → 结果 [2, 3],入队右子节点 6

    queue = [4, 5, 6]

  1. 访问第三层
  • 访问 4, 5, 6 → 结果 [4, 5, 6]

  • 没有子节点,队列为空,结束


最终层序遍历结果:

复制代码
[[1], [2, 3], [4, 5, 6]]

✅ 可以看到,先访问每一层的所有节点,再进入下一层,这就是 BFS。


如果你愿意,我可以帮你画一张 队列推进示意图,让你一眼就能看懂每一步队列里存的节点和访问顺序,非常直观。

你想让我画吗?

相关推荐
IronMurphy5 分钟前
【算法五十七】146. LRU 缓存
算法·缓存
Irissgwe23 分钟前
数据结构-栈和队列
数据结构·c++·c·栈和队列
两片空白33 分钟前
数据容器集合set/frozenset
数据结构
凌波粒38 分钟前
LeetCode--108.将有序数组转换为二叉搜索树(二叉树)
算法·leetcode·职场和发展
liulilittle38 分钟前
KCC:在 BBR 思路上的一次探索
网络·tcp/ip·算法·bbr·通信·拥塞控制·kcc
浦信仿真大讲堂1 小时前
达索系统SIMULIA Abaqus 2026接触和约束的增强新功能介绍
人工智能·python·算法·仿真软件·达索软件
点云侠1 小时前
PCL 生成三棱锥点云
c++·算法·最小二乘法
代码中介商1 小时前
跳表:高效查找的链表黑科技
数据结构
兰令水1 小时前
leecodecode【面试150】【2026.6.13打卡-java版本】
java·算法·leetcode
临沂堇1 小时前
刷题日志 | Leetcode Hot 100 哈希
算法·leetcode·哈希算法