【算法刷题 | 二叉树 02】3.21 二叉树的层序遍历01(5题:二叉树的层序遍历、层序遍历||、右视图、层平均值,以及N叉树的层序遍历)

文章目录

  • 5.二叉树的层序遍历
    • 5.1 102_二叉树的层序遍历
      • 5.1.1问题
      • 5.1.2解法:队列
    • 5.2 107_二叉树的层序遍历||
      • 5.2.1问题
      • 5.2.2解法:队列
    • 5.3 199_二叉树的右视图
      • 5.3.1问题
      • 5.3.2解决:队列
    • 5.4 637_二叉树的层平均值
      • 5.4.1问题
      • 5.4.2解决:队列
    • 5.5 429_N叉树的层序遍历
      • 5.5.1问题
      • 5.5.2解法:层序遍历+栈

5.二叉树的层序遍历

5.1 102_二叉树的层序遍历

5.1.1问题

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

102.二叉树的层序遍历

5.1.2解法:队列

  1. 层序遍历需要借用一个辅助数据结构,即 队列 来实现
  2. 队列先进先出,符合一层一层遍历的逻辑
  3. 首先将根节点添加到队列中,接着开启一个循环(只要队列不为空,就一直循环)
    1. 在每次循环中,先拿到此时队列的长度
    2. 接着依次取出此时队列的全部节点(先进先出),并处理该元素
    3. 若该节点的左孩子不为空,则添加进队列;若该节点的右孩子不为空,则添加进队列
    4. 每次循环中,将处理完的list数组添加到返回值即可

102二叉树的层序遍历

class Solution {
    public List<List<Integer>> levelOrder(TreeNode root) {

        //1、借助队列实现:先进先出
        Queue<TreeNode> queue=new LinkedList<>();
        List<List<Integer>> list=new ArrayList<>();
        if(root==null){
            return list;
        }

        //添加根节点到队列
        queue.offer(root);
        while(!queue.isEmpty()){
            //只要队列不为空,就一直循环
            List<Integer> tmp=new ArrayList<>();
            //取出队列全部元素
            int len=queue.size();
            while(len>0){
                
                TreeNode node=queue.poll();
                //添加值
                tmp.add(node.val);                                 
                
                if(node.left!=null){
                    queue.offer(node.left);
                }
                if(node.right!=null){
                    queue.offer(node.right);
                }
                len--;
            }
            
            list.add(tmp);
        }
        return list;

        
    }
}

5.2 107_二叉树的层序遍历||

5.2.1问题

给定一个二叉树,返回其 节点值自底向上 的层次遍历。 (即按从叶子节点所在层到根节点所在的层,逐层从左向右遍历)

107.二叉树的层次遍历II

5.2.2解法:队列

  1. 思路:跟上一题一样,使用队列解决
  2. 由于是自底向上,所以结果反转list即可
class Solution {
    public List<List<Integer>> levelOrderBottom(TreeNode root) {
        Queue<TreeNode> queue=new LinkedList<>();
        List<List<Integer>> list=new ArrayList<>();
        if(root==null){
            return list;
        }
        queue.offer(root);
        while(!queue.isEmpty()){
            //遍历该层
            List<Integer> tmp=new ArrayList<>();
            int len=queue.size();
            while(len>0){
                TreeNode node=queue.poll();
                tmp.add(node.val);
                if(node.left!=null){
                    queue.offer(node.left);
                }
                if(node.right!=null){
                    queue.offer(node.right);
                }
                len--;
            }

            //将该层结果添加到返回list中
            list.add(tmp);
        }

        //反转,也可以新建一个list,从后往前遍历原来的list
        Collections.reverse(list);
        return list;
        
    }
}

5.3 199_二叉树的右视图

5.3.1问题

给定一个二叉树的 根节点 root,想象自己站在它的右侧,按照从顶部到底部的顺序,返回从右侧所能看到的节点值。

  • 示例一:

img

输入: [1,2,3,null,5,null,4]
输出: [1,3,4]

5.3.2解决:队列

  1. 思路:层序遍历,将每层的最右节点添加到返回list中即可
class Solution {
    public List<Integer> rightSideView(TreeNode root) {
        Queue<TreeNode> queue=new LinkedList<>();
        List<Integer> list=new ArrayList<>();

        if(root==null){
            return list;
        }

        queue.offer(root);
        while(!queue.isEmpty()){
            int len=queue.size();
            for(int i=0;i<len;i++){
                
                TreeNode node=queue.poll();
                if(i==len-1){
                    //每层的最后一个
                    list.add(node.val);
                }

                if(node.left!=null){
                    queue.offer(node.left);
                }
                if(node.right!=null){
                    queue.offer(node.right);
                }
            }
            
        }
        return list;
    }
}

5.4 637_二叉树的层平均值

5.4.1问题

给定一个非空二叉树的根节点 root , 以数组的形式返回每一层节点的平均值。与实际答案相差 10-5 以内的答案可以被接受。

  • 示例一:

img

输入:root = [3,9,20,null,null,15,7]
输出:[3.00000,14.50000,11.00000]
解释:第 0 层的平均值为 3,第 1 层的平均值为 14.5,第 2 层的平均值为 11 。
因此返回 [3, 14.5, 11] 。

5.4.2解决:队列

class Solution {
    public List<Double> averageOfLevels(TreeNode root) {

        Queue<TreeNode> queue=new LinkedList<>();
        List<Double> list=new ArrayList<>();
        if(root==null){
            return list;
        }
        queue.offer(root);
        while(!queue.isEmpty()){
            //遍历该层
            int len=queue.size();
            Double tmp=0.0;

            for(int i=0;i<len;i++){
                TreeNode node=queue.poll();
                tmp+=node.val;
                if(node.left!=null){
                    queue.offer(node.left);
                }
                if(node.right!=null){
                    queue.offer(node.right);
                }
            }

            //将该层结果添加到返回list中
            list.add(tmp/len);
        }

        return list;
    }
}

5.5 429_N叉树的层序遍历

5.5.1问题

给定一个 N 叉树,返回其节点值的层序遍历。(即从左到右,逐层遍历)。

树的序列化输入是用层序遍历,每组子节点都由 null 值分隔(参见示例)。

  • 示例一:

img

输入:root = [1,null,3,2,4,null,5,6]
输出:[[1],[3,2,4],[5,6]]

5.5.2解法:层序遍历+栈

class Solution {
    public List<List<Integer>> levelOrder(Node root) {
        Queue<Node> queue=new LinkedList<>();
        List<List<Integer>> list=new ArrayList<>();
        if(root==null){
            return list;
        } 
        queue.offer(root);
        while(!queue.isEmpty()){
            int len=queue.size();
            List<Integer> tmp=new ArrayList<>();
            while(len>0){
                Node node=queue.poll();
                tmp.add(node.val);
                
                //由左右节点变成孩子节点
                List<Node> childrens=node.children;
                for(Node children:childrens){
                    if(children!=null){
                        queue.offer(children);
                    }
                }
                len--;
            }
            list.add(tmp);
        }
        return list;
    }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/480578.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Dell戴尔XPS 12 9250二合一笔记本电脑原装出厂Windows10系统包下载

链接&#xff1a;https://pan.baidu.com/s/1rqUEM_q5DznF0om6eevcwg?pwdvij0 提取码&#xff1a;vij0 戴尔原厂WIN10系统自带所有驱动、出厂主题壁纸、系统属性专属联机支持标志、系统属性专属LOGO标志、Office办公软件、MyDell等预装程序 文件格式&#xff1a;esd/wim/sw…

API调试管理工具Postman下载及操作介绍

1.下载安装postman地址&#xff1a;https://www.getpostman.com/downloads/ 2.创建项目 3.创建请求API 然后点击save保存api 4.用一个变量保存主域名&#xff0c;方便后续操作 就类似下面的baseurl 5.创建新环境 6.添加变量&#xff08;如添加本地测试环境url——ba…

Qt如何直接处理系统事件(比如鼠标事件),而不是post事件

#include <QtGui/5.15.2/QtGui/qpa/qwindowsysteminterface.h> // 方便调试事件 QWindowSystemInterface::setSynchronousWindowSystemEvents(true); 直接再 qWindowsWndProc函数中处理 通常情况: 事件被放到一个队列中

Leetcode 101. 对称二叉树

心路历程&#xff1a; 这道题没有想象中那么简单。其最难的地方就在于如何判断两个子树相等这件事上&#xff0c;无法直接left right&#xff0c;因为毕竟只是指针。 本道题思考了三种解法&#xff0c;其中一种很可惜没有完全AC。 注意的点&#xff1a; 1、root.left root…

浙江IGM机器人K5控制柜维修需要注意哪些问题?

IGM机器人K5控制柜常见故障及维修方法 1、电源故障&#xff1a; 表现为IGM机器人K5控制柜不能开机或突然断电。 检查&#xff1a;检查电源线是否连接良好&#xff0c;有无破损&#xff1b;检查电源模块的输出电压是否正常&#xff1b; 维修方法&#xff1a;如电源模块损坏&…

【并查集专题】【蓝桥杯备考训练】:网络分析、奶酪、合并集合、连通块中点的数量、格子游戏【已更新完成】

目录 1、网络分析&#xff08;第十一届蓝桥杯省赛第一场C A组/B组&#xff09; 2、奶酪&#xff08;NOIP2017提高组&#xff09; 3、合并集合&#xff08;模板&#xff09; 4、连通块中点的数量&#xff08;模板&#xff09; 5、格子游戏&#xff08;《信息学奥赛一本通》…

DashVector - 阿里云向量检索服务

DashVector 文章目录 DashVector一、关于 DashVector二、使用 DashVector 前提准备1、创建Cluster&#xff1a;2、获得API-KEY3、安装最新版SDK 三、快速使用 DashVector1. 创建Client2. 创建Collection3、插入Doc4、相似性检索5、删除Doc6. 查看Collection统计信息7. 删除Coll…

jeect-boot queryFieldBySql接口RCE漏洞(CVE-2023-4450)复现

jeect-boot积木报表由于未授权的 API /jmreport/queryFieldBySql 使用了 freemarker 解析 SQL 语句从而导致了 RCE 漏洞的产生。 1.漏洞级别 高危 2.漏洞搜索 fofa app"Jeecg-Boot 企业级快速开发平台"3.影响范围 JimuReport < 1.6.14.漏洞复现 这个漏洞的…

(done) 机器学习中的方差 variance 和 偏差 bias 怎么理解?

来源&#xff1a;https://blog.csdn.net/weixin_41479678/article/details/116230631 情况1属于&#xff1a;低 bias&#xff0c;高 variance (和 human performance 相近&#xff0c;但和 验证集dev set 相远) 通常意味着模型训练轮数太多 情况2属于&#xff1a;高 bias&#…

uniapp自定义导航栏左中右内容和图标,以及点击事件

uniapp自定义导航栏左中右内容和图标&#xff0c;以及点击事件 效果&#xff1a; 页面&#xff1a; <view class"navigation-bar"><view class"navigation-bar-left" click"navigateBack"><u-icon name"arrow-left"…

StarRocks-2.5.13部署安装

1、安装jdk11 tar xf jdk-11.0.16.1_linux-x64_bin.tar.gz mv jdk-11.0.16.1 /data/soft/jdk-11 # 配置在/etc/profile中 export JAVA_HOME/data/soft/jdk-11 export CLASSPATH.:/data/soft/jdk-11/lib export PATH/data/soft/jdk-11/bin:$PATH # 验证jdk [rootdb-public-03 s…

就业班 第二阶段 2401--3.19 day4 主从复制

一、MySQL-Replication&#xff08;主从复制&#xff09; 1.1、MySQL Replication 主从复制&#xff08;也称 AB 复制&#xff09;允许将来自一个MySQL数据库服务器&#xff08;主服务器&#xff09;的数据复制到一个或多个MySQL数据库服务器&#xff08;从服务器&#xff09;…

open3d | ubuntu源码编译open3d

# clone源码 git clone https://github.com/isl-org/Open3D# 安装依赖 cd Open3D util/install_deps_ubuntu.sh# 安装anaconda3&#xff0c;略过~ conda create -n open3d_py39 python3.9 conda activate open3d_py39# 查看一下python路径 which pythonmkdir build cd build# c…

Linus进程控制

进程创建 fork 函数 在linux中fork函数时非常重要的函数&#xff0c;它从已存在进程中创建一个新进程。新进程为子进程&#xff0c;而原进程为父进程。 #include <unistd.h> pid_t fork(void); 返回值&#xff1a;子进程中返回0&#xff0c;父进程返回子进程id&#x…

GraphPad Prism 10:一站式数据分析解决方案

GraphPad Prism 10是一款功能强大的数据分析和可视化软件&#xff0c;广泛应用于生命科学研究、医学、生物、化学等多个领域。以下是对其详细功能的介绍&#xff1a; 首先&#xff0c;GraphPad Prism 10具有出色的数据可视化功能。它支持各种类型的图表和图形&#xff0c;包括…

C语言预编译#pragma宏的作用

在嵌入式编程中&#xff0c;#pragma 指令具有非常重要的作用&#xff0c;因为它允许开发者在不同的编译器之间传达特定的编译指令。由于嵌入式编程通常与硬件紧密相关&#xff0c;且资源有限&#xff0c;这些指令可以帮助开发者更有效地利用可用资源&#xff0c;优化程序&#…

【UVM_event_pool RAL TLM_2024.03.18】

event pool uvm_event 用于同步或者通信&#xff0c;由object派生 ->:trigger event :wait eventwait_trigger();//相同时间触发与等待&#xff0c;不一定能等到该事件 wait_ptrigger();//一定能等到该事件&#xff0c;在while循环中会造成一直触发uvm_pool 共享的内存空…

Github多账号切换

在开发阶段&#xff0c;如果同时拥有多个开源代码托管平台的账户&#xff0c;在代码的管理上非常麻烦。那么&#xff0c;如果同一台机器上需要配置多个账户&#xff0c;怎样才能确保不冲突&#xff0c;不同账户独立下载独立提交呢&#xff1f; 我们以两个github账号进行演示 …

51单片机中断信号的种类及应用场景

在嵌入式系统中&#xff0c;中断是一种重要的事件处理机制&#xff0c;它可以在程序执行的任何时候暂停当前任务&#xff0c;转而执行与之相关的特殊任务或事件。51单片机作为一种常见的微控制器&#xff0c;其中断功能在各种应用中起着关键作用。然而&#xff0c;对于初学者和…

深度学习中的随机种子random_seed

解释 由于模型中的参数初始化例如权重参数如下图&#xff0c;就是随机初始化的&#xff0c;为了能够更好的得到论文中提到效果&#xff0c;可以设置随机种子&#xff0c;从而减少算法结果的随机性&#xff0c;使其接近于原始结果。 设置了随机种子&#xff0c;产生的随机数都…