【数据结构】二叉树-图解广度优先搜索

广度优先搜索

广度优先搜索就是基于 队列 去一层一层地遍历二叉树,最常见的方式就是层序遍历 ,使用的是迭代法 。假如每一层元素的值都用一个数组去存储,那么最终会是一个二维数组的形式。
为什么要基于队列去实现?

假如存在一个如下二叉树,当我们遍历到第二层时,需要先保存元素 4 与 7,再回过头遍历元素 4 底下的其他元素。也就是说我们需要用一个可以保存元素的容器 - 队列,借助它来保存每一层内我们遍历过的元素。

除了读取出元素并直接存入队列以外,还要维护一个 size 值,用于表示当前层的元素数量,借助 size 就可以准确从队列当中弹出对应数量的元素。接下来将以流程图形式展示层序遍历的流程:

代码实现:

java 复制代码
public List<List<Integer>> levelOrder(TreeNode root) {
        List<List<Integer>> res = new ArrayList<>();
        if(root == null) return res;
        
        Queue<TreeNode> nodeQueue = new LinkedList<>();
        nodeQueue.add(root);
        
        while(!nodeQueue.isEmpty()) {
            int size = nodeQueue.size();
            List<Integer> nodeList = new ArrayList<>(size);
            
            while(size > 0) {
                TreeNode temp = nodeQueue.poll();
                nodeList.add(temp.val);
                if(temp.left != null) nodeQueue.add(temp.left);
                if(temp.right != null) nodeQueue.add(temp.right);
                size--;
            }
            
            res.add(nodeList);
        }
        
        return res;
    }
相关推荐
皙然16 分钟前
深入拆解MESI协议:从原理到实战,搞懂CPU缓存一致性的核心机制
java·缓存
NAGNIP18 分钟前
一文搞懂CNN经典架构-AlexNet!
人工智能·算法
愤豆21 分钟前
02-Java语言核心-语法特性-注解体系详解
java·开发语言·python
晴栀ay35 分钟前
Generator + RxJS 重构 LLM 流式输出的“丝滑”架构
javascript·后端·llm
下次一定x39 分钟前
深度解析 Kratos 客户端服务发现与负载均衡:从 Dial 入口到 gRPC 全链路落地(下篇)
后端·go
2401_8785302144 分钟前
自定义内存布局控制
开发语言·c++·算法
x-cmd44 分钟前
[x-cmd] 终端里的飞书:lark-cli,让 AI Agent 拥有“实体办公”能力
java·人工智能·ai·飞书·agent·x-cmd
专注VB编程开发20年44 分钟前
PNG、GIF透明游戏角色人物输出一张图片技巧,宽度高度读取
算法
CoderCodingNo1 小时前
【CSP】CSP-J 2025真题 | 异或和 luogu-P14359 (相当于GESP六级水平)
算法
keep intensify1 小时前
打家劫舍3
算法·深度优先