【LeetCode Hot100 | 每日刷题】二叉树的层序遍历

题目:

给你二叉树的根节点 root ,返回其节点值的 层序遍历 。 (即逐层地,从左到右访问所有节点)。

示例 1:

复制代码
输入:root = [3,9,20,null,null,15,7]
输出:[[3],[9,20],[15,7]]

示例 2:

复制代码
输入:root = [1]
输出:[[1]]

示例 3:

复制代码
输入:root = []
输出:[]

难点:

需要把每一层的节点值都单独存储到一个list集合中,也就是最后返回结果需要是List<List<Integer>>类型的。

思路:

对该树进行BFS,利用Java的ArrayDeque 队列,每一层单独来一次循环以该层的节点数为循环截止条件。

过程如下:

可以看到,在 while 循环的每一轮中,都是将当前层的所有结点出队列,再将下一层的所有结点入队列,这样就实现了层序遍历。

Java代码:

java 复制代码
class Solution {
    public List<List<Integer>> levelOrder(TreeNode root) {
        ArrayList<List<Integer>>res=new ArrayList<>();
        Queue<TreeNode>qu=new ArrayDeque<>();
        if(root!=null){
            qu.add(root);
        }
        while(!qu.isEmpty()){
            List<Integer>list=new ArrayList<>();
            int n=qu.size();
            for(int i=0;i<n;i++){
                TreeNode node=qu.poll();
                list.add(node.val);
                if(node.left!=null){
                    qu.add(node.left);
                }
                if(node.right!=null){
                    qu.add(node.right);
                }
            }
            res.add(list);
        }
        return res;
    }
}
相关推荐
子豪-中国机器人1 小时前
2025年5月18日蓝桥stema省选拔赛编程题答案解析
c++·算法·数学建模
极光雨雨1 小时前
【算法】回溯法
算法
君鼎1 小时前
排序算法——详解
数据结构·算法·排序算法
岁忧1 小时前
LeetCode 高频 SQL 50 题(基础版) 之 【高级查询和连接】· 上
数据库·sql·leetcode
Felven1 小时前
A. AvtoBus
算法
卫青~护驾!2 小时前
c++数据结构8——二叉树的性质
数据结构·算法
飞川撸码2 小时前
【LeetCode 热题100】BFS/DFS 实战:岛屿数量 & 腐烂的橘子(力扣200 / 994 )(Go语言版)
leetcode·深度优先·宽度优先
半桔2 小时前
【烧脑算法】不定长滑动窗口:从动态调整到精准匹配以灵活特性实现高效破题
数据结构·c++·算法·leetcode·面试·职场和发展·排序算法
不会敲代码的灵长类3 小时前
机器学习算法-逻辑回归
算法·机器学习·逻辑回归
拓端研究室TRL3 小时前
消费者网络购物意向分析:调优逻辑回归LR与决策树模型在电商用户购买预测中的应用及特征重要性优化
人工智能·算法·决策树·机器学习·逻辑回归