2024.2.14力扣每日一题——二叉树的层序遍历

2024.2.14

      • 题目来源
      • 我的题解
        • [方法一 递归实现(前序遍历+记录深度)](#方法一 递归实现(前序遍历+记录深度))
        • [方法二 非递归实现(队列)](#方法二 非递归实现(队列))

题目来源

力扣每日一题;题序:102

我的题解

方法一 递归实现(前序遍历+记录深度)

在递归遍历时记录节点所在的深度,然后把值加入到对应的深度的链表中。并利用List的set方法更新对应层次的元素List
时间复杂度 :O(n)。遍历所有节点
空间复杂度:O(n)。递归空间的大小

java 复制代码
public List<List<Integer>> levelOrder(TreeNode root) {
    List<List<Integer>> res=new ArrayList<>();
    if(root==null)
        return res;
    levelOrder1(root,0,res);
    return res;
}
public void levelOrder1(TreeNode root,int level,List<List<Integer>> res){
    if(root==null)
        return ;
    // 已经遍历过的层次
    if(res.size()>level){
        List<Integer> list=res.get(level);
        list.add(root.val);
        res.set(level,list);
    // 还未遍历的层次 
    }else{
        List<Integer> list=new ArrayList<>();
        list.add(root.val);
        res.add(list);
    }
    levelOrder1(root.left,level+1,res);
    levelOrder1(root.right,level+1,res);
}
方法二 非递归实现(队列)

利用队列的先进先出的特性,将每一行的节点从左到右存入队列中,然后以此取出进行遍历,再加入相应的子节点。
时间复杂度:O(n)。需要遍历所有节点

空间复杂度:O(n)。队列需要的空间

java 复制代码
public List<List<Integer>> levelOrder(TreeNode root) {
    List<List<Integer>> res=new ArrayList<>();
    if(root==null)
        return res;
    Queue<TreeNode> queue=new LinkedList<>();
    queue.offer(root);
    while(!queue.isEmpty()){
        int sz=queue.size();
        List<Integer> temp=new ArrayList<>();
        for(int i=0;i<sz;i++){
            TreeNode t=queue.poll();
            temp.add(t.val);
            if(t.left!=null)
                queue.offer(t.left);
            if(t.right!=null)
                queue.offer(t.right);
        }
        res.add(temp);
    }
    return res;
}

有任何问题,欢迎评论区交流,欢迎评论区提供其它解题思路(代码),也可以点个赞支持一下作者哈😄~

相关推荐
xsyaaaan21 分钟前
leetcode-hot100-双指针:283移动零-11盛最多水的容器-15三数之和-42接雨水
算法·leetcode
炽烈小老头4 小时前
【每天学习一点算法 2026/03/08】相交链表
学习·算法·链表
HalvmånEver4 小时前
7.高并发内存池大页内存申请释放以及使用定长内存池脱离new
java·spring boot·spring
凤山老林4 小时前
SpringBoot 使用 H2 文本数据库构建轻量级应用
java·数据库·spring boot·后端
一碗白开水一4 小时前
【工具相关】OpenClaw 配置使用飞书:打造智能飞书助手全流程指南(亲测有效,放心享用)
人工智能·深度学习·算法·飞书
仰泳的熊猫4 小时前
题目2194:蓝桥杯2018年第九届真题-递增三元组
数据结构·c++·算法
Tisfy5 小时前
LeetCode 1888.使二进制字符串字符交替的最少反转次数:前缀和O(1)
算法·leetcode·字符串·题解
赶路人儿5 小时前
UTC时间和时间戳介绍
java·开发语言
dreamread5 小时前
【SpringBoot整合系列】SpringBoot3.x整合Swagger
java·spring boot·后端
6+h5 小时前
【java】基本数据类型与包装类:拆箱装箱机制
java·开发语言·python