【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;
    }
}
相关推荐
Susea&40 分钟前
趣味编程:梦幻万花筒
c语言·算法·技术美术
半桔44 分钟前
定长滑动窗口---初阶篇
数据结构·c++·算法·leetcode·面试
灏瀚星空1 小时前
深度学习之LSTM时序预测:策略原理深度解析及可视化实现
python·深度学习·神经网络·算法·机器学习·数学建模·lstm
CodeJourney.2 小时前
MATLAB三维可视化技术解析
数据库·人工智能·算法·matlab
元亓亓亓2 小时前
LeetCode热题100--73.矩阵置零--中等
算法·leetcode·矩阵
泛舟起晶浪3 小时前
推导部分和-图论+dfs+连通块
算法·深度优先·图论
程序媛小盐3 小时前
动态规划背包问题
算法·动态规划
PixelMind4 小时前
【LUT技术专题】基于扩展卷积的极快速LUT算法
算法
SeasonedDriverDG4 小时前
GEC6818蜂鸣器驱动开发
算法
悦悦子a啊4 小时前
第八章--图
数据结构·c++·算法