Day15:二叉树层序遍历 LeedCode 102.二叉树的层序遍历 199二叉树的右视图 637.二叉树的层平均值 101.对称二叉树 226.翻转二叉树

news2024/11/24 14:14:24

 102.二叉树的层序遍历

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

示例 1:

输入:root = [3,9,20,null,null,15,7]
输出:[[3],[9,20],[15,7]]

思路:利用队列的先进先出特点,依次将左子树和右子树入队列,每次循环结束后,队列里都存放的新一层的所有结点,依次将这些结点的左右子树入队列,可以得到下一层的所有结点

图解:

 迭代法

class Solution {
    public List<List<Integer>> levelOrder(TreeNode root) {
         List<List<Integer>> list=new ArrayList<>();
         if(root==null){
            return list;
         }
         Queue<TreeNode> myQueue=new LinkedList<>();
         TreeNode cur=root;
         myQueue.offer(cur);
        while(!myQueue.isEmpty()){
            List<Integer>list1=new ArrayList<>();
//队列中存放着上一层的所有结点
//len记录上一层所有结点的个数
            int len=myQueue.size();
            while(len-->0){
                TreeNode temp=myQueue.poll();
                list1.add(temp.val);
                if(temp.left!=null){myQueue.offer(temp.left);}
                if(temp.right!=null){myQueue.offer(temp.right);}
            }
            list.add(list1);
        }
        return list;
    }
}

递归法 

 在先序遍历的基础上加入深度length

class Solution {
    public List<List<Integer>> levelOrder(TreeNode root) {
         List<List<Integer>> list=new ArrayList<>();
         order(root,list,0);
         return list;
    }
    public void order(TreeNode cur, List<List<Integer>> list,int length){
       if(cur==null){
        return;
       }
       if(list.size()==length)
       list.add(new ArrayList<Integer>());
//利用list的索引值进行层级界定
       list.get(length).add(cur.val);
       order(cur.left,list,length+1);
       order(cur.right,list,length+1);
    }
}

以下题目均类似:

107. 二叉树的层序遍历 II

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

class Solution {
    public List<List<Integer>> levelOrderBottom(TreeNode root) {
       List<List<Integer>>list=new ArrayList<List<Integer>>();
       order(root,list,0);
       Collections.reverse(list);
       return list;
    }
    public void order(TreeNode cur,List<List<Integer>> list,int length){
        if(cur==null)
        return;
        if(length==list.size()){
            list.add(new ArrayList<Integer>());
        }
        list.get(length).add(cur.val);
        order(cur.left,list,length+1);
        order(cur.right,list,length+1);
    }
}

199. 二叉树的右视图

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

思路:在层序遍历的基础上将每层最后一个元素放入list

class Solution {
    public List<Integer> rightSideView(TreeNode root) {
       List<Integer>list=new ArrayList<>();
       if(root==null)
       return list;
        Queue<TreeNode> muQ=new LinkedList<TreeNode> ();
        muQ.offer(root);
        while(!muQ.isEmpty()){
            int len=muQ.size();
            while(len-->0){
            TreeNode  temp=muQ.poll();
            if(len==0)list.add(temp.val);
            if(temp.left!=null) muQ.add(temp.left);
            if(temp.right!=null) muQ.add(temp.right);
            }
        }
        return list;

    }
}

637. 二叉树的层平均值

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

注意:相加的结果会超过int表示范围

    public List<Double> averageOfLevels(TreeNode root) {
    List <Double> list=new ArrayList<>();
    if(root==null)
       return list;
        Queue<TreeNode> muQ=new LinkedList<TreeNode> ();
        muQ.offer(root);
        while(!muQ.isEmpty()){
            int len=muQ.size();
            long sums=0;
            int nums=len;
            while(len-->0){
            TreeNode  temp=muQ.poll();
            sums+=temp.val;
            if(temp.left!=null) muQ.add(temp.left);
            if(temp.right!=null) muQ.add(temp.right);
            }
            list.add(sums*1.0/nums);
        }
    return list;
    }
   
}

429. N 叉树的层序遍历

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

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

 思路:将二叉树层序遍历的模版中将左右孩子结点加入队列改成将孩子结点(0-N个)加入队列

class Solution {
    public List<List<Integer>> levelOrder(Node root) {
  List<List<Integer>> list=new ArrayList<>();
         if(root==null){
            return list;
         }
         Queue<Node> myQueue=new LinkedList<>();
         Node cur=root;
         myQueue.offer(cur);
        while(!myQueue.isEmpty()){
            List<Integer>list1=new ArrayList<>();
            int len=myQueue.size();
            while(len-->0){
                Node temp=myQueue.poll();
                list1.add(temp.val);
                List<Node> children=temp.children;
                int i=0;;
                while(i<children.size()){
                    myQueue.add(children.get(i));
                    i++;
                }
            }
            list.add(list1);
        }
        return list;

      }
}

515. 在每个树行中找最大值

给定一棵二叉树的根节点 root ,请找出该二叉树中每一层的最大值。

 思路:与637二叉树的层平均值相似

class Solution {
    public List<Integer> largestValues(TreeNode root) {
  List <Integer> list=new ArrayList<>();
    if(root==null)
       return list;
        Queue<TreeNode> muQ=new LinkedList<TreeNode> ();
        muQ.offer(root);
        while(!muQ.isEmpty()){
            int len=muQ.size();
            int maxx=Integer.MIN_VALUE;
            while(len-->0){
            TreeNode  temp=muQ.poll();
            maxx=Math.max(maxx,temp.val);
            if(temp.left!=null) muQ.add(temp.left);
            if(temp.right!=null) muQ.add(temp.right);
            }
            list.add(maxx);
        }
    return list;
    }
}

116. 填充每个节点的下一个右侧节点指针

给定一个 完美二叉树 ,其所有叶子节点都在同一层,每个父节点都有两个子节点。二叉树定义如下:

struct Node {
  int val;
  Node *left;
  Node *right;
  Node *next;
}

填充它的每个 next 指针,让这个指针指向其下一个右侧节点。如果找不到下一个右侧节点,则将 next 指针设置为 NULL

初始状态下,所有 next 指针都被设置为 NULL

思路:层序遍历时,当前结点指向下一结点

117. 填充每个节点的下一个右侧节点指针 II也是一样做法

class Solution {
    public Node connect(Node root) {
    if(root==null)
       return root;
        Queue<Node> muQ=new LinkedList<Node> ();
        muQ.offer(root);
        while(!muQ.isEmpty()){
            int len=muQ.size();
             Node  temp=null;
             Node   next=null;
            while(len-->0){
              temp=muQ.poll();
              if(len>0) next=muQ.peek();
              else{next=null;}
              temp.next=next;
            if(temp.left!=null) muQ.add(temp.left);
            if(temp.right!=null) muQ.add(temp.right);
            }
        }
    return root;
    }
}

104. 二叉树的最大深度

class Solution {
    public int maxDepth(TreeNode root) {
            int length=0;
         if(root==null){
            return length;
         }
         Queue<TreeNode> myQueue=new LinkedList<>();
         TreeNode cur=root;
         myQueue.offer(cur);
        while(!myQueue.isEmpty()){
            List<Integer>list1=new ArrayList<>();
            int len=myQueue.size();
            while(len-->0){
                TreeNode temp=myQueue.poll();
                if(temp.left!=null){myQueue.offer(temp.left);}
                if(temp.right!=null){myQueue.offer(temp.right);}
            }
            length++;

        }
        return length;
    }
}

111. 二叉树的最小深度

给定一个二叉树,找出其最小深度。

最小深度是从根节点到最近叶子节点的最短路径上的节点数量。

说明:叶子节点是指没有子节点的节点

 思路:层序遍历到左右孩子都为空的结点时,这个结点的深度就是树的最小深度 

class Solution {
    public int minDepth(TreeNode root) {
        int length=0;
         if(root==null){
            return length;
         }
         Queue<TreeNode> myQueue=new LinkedList<>();
         TreeNode cur=root;
         myQueue.offer(cur);
        while(!myQueue.isEmpty()){
            List<Integer>list1=new ArrayList<>();
            int len=myQueue.size();
            while(len-->0){
                TreeNode temp=myQueue.poll();
                if(temp.left==null&&temp.right==null){
                    return length+1;
                }
                if(temp.left!=null){myQueue.offer(temp.left);}
                if(temp.right!=null){myQueue.offer(temp.right);}
            }
            length++;

        }
        return length;
    }
}

101. 对称二叉树

给你一个二叉树的根节点 root , 检查它是否轴对称。

示例 1:

输入:root = [1,2,2,3,4,4,3]
输出:true

思路:本题遍历只能是“后序遍历”,因为我们要通过递归函数的返回值来判断两个子树的内侧节点和外侧节点是否相等。一个树的遍历顺序是左右中,一个树的遍历顺序是右左中。我们要比较的是根节点的两个子树是否是相互翻转的,进而判断这个树是不是对称树,所以要比较的是两个树,参数自然也是左子树节点和右子树节点。

1.确定传递参数

因为我们要比较的是根节点的两个子树是否是相互翻转的,进而判断这个树是不是对称树,所以要比较的是两个树,参数自然也是左子树节点和右子树节点。

返回值自然是bool类型。

bool compare(TreeNode* left, TreeNode* right)

2.确定终止条件

要比较两个节点数值相不相同,首先要把两个节点为空的情况弄清楚!否则后面比较数值的时候就会操作空指针了。

  • 左节点为空,右节点不为空,return false
  • 左不为空,右为空 return false
  • 左右都为空,对称,返回true
  • 左右都不为空,比较节点数值,不相同就return false

3.确定单层递归的逻辑

此时才进入单层递归的逻辑,单层递归的逻辑就是处理 左右节点都不为空,且数值相同的情况。

  • 比较二叉树外侧是否对称:传入的是左节点的左孩子,右节点的右孩子。
  • 比较内侧是否对称,传入左节点的右孩子,右节点的左孩子。
  • 如果左右都对称就返回true ,有一侧不对称就返回false 。

 

class Solution {
    public boolean isSymmetric(TreeNode root) {
     if(root==null)
      return true;
      return Comparet(root.left,root.right);
    }

    public boolean Comparet(TreeNode left,TreeNode right){
    if(left==null&&right==null){return true;}
    else if(left==null&&right!=null){return false; }
    else if(left!=null&&right==null){return false;}
    else{
        if(left.val!=right.val) return false;
    }
    //左右结点值相等,这两棵树才会是翻转树
    boolean l1=Comparet(left.left,right.right);
    boolean l2=Comparet(left.right,right.left);
    return l1&&l2;
    }
}

226. 翻转二叉树

给你一棵二叉树的根节点 root ,翻转这棵二叉树,并返回其根节点。

示例 1:

输入:root = [4,2,7,1,3,6,9]
输出:[4,7,2,9,6,3,1]

思路:采用递归的思想,先翻转左子树,再翻转右子树,然后翻转当前结点

class Solution {
    public TreeNode invertTree(TreeNode root) {
        if(root==null)
        return root;
        invertTree(root.left);
        invertTree(root.right);
        TreeNode temp=root.left;
        root.left=root.right;
        root.right=temp;
        return root;
    }
}

采用先序遍历,先翻转当前结点,再翻转左右结点

class Solution {
    public TreeNode invertTree(TreeNode root) {
        if(root==null)
        return root;   
        TreeNode temp=root.left;
        root.left=root.right;
        root.right=temp;
          invertTree(root.left);
        invertTree(root.right);
        return root;
    }
}

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

汇丰:大宗商品的“供给侧大故事”

今年3月以来&#xff0c;黄金、铜、原油、可可等各类大宗商品价格开启“狂飙”模式。 国际黄金从每盎司2050美元涨至接近2200美元&#xff1b;作为全球经济晴雨表&#xff0c;伦铜价格已经突破9000美元/吨&#xff0c;创近1年新高&#xff1b;原油价格也连续上涨&#xff0c;I…

采用U盘安装Win10系统教程

安装流程&#xff1a; 下载 Windows 10https://www.microsoft.com/zh-cn/software-download/windows10 手把手教你如何重装win10系统&#xff0c;自己动手安装系统其实很简单 - 知乎笔者在这里写一个详细点的系统重装教程。手把手教大家如何从零开始重装win10系统。因为是写给新…

CPU设计实战-Wishbone总线接口

为什么需要改用总线接口&#xff1f; 1.但是在实际应用中&#xff0c;程序的体积可能非常大&#xff0c;指令存储器就不能再集成在FPGA内部了&#xff0c;一般使用FPGA芯片外部的Flash作为指令存储器。同理,-般使用FPGA芯片外部的SDRAM作为数据存储器。 2.统一接口标准。 很多…

科研学习|研究方法——实验法

1.实验方法的渊源 今天我们说物理学、生物学是实验的科学&#xff0c;应该不会有人再持异议了&#xff0c;然而连物理学这样的学科在历史上也并非一开始就是实验科学。在2000多年以前的亚里士多德时代&#xff0c;众人都认为物理学是非实验性质的&#xff0c;物理学成为实验科学…

cuda多版本安装

主要参考文章&#xff1a; ubuntu 20.04下多版本cuda&cudnn下载与安装 在ubuntu上安装多个版本的CUDA&#xff0c;并且可以随时切换 1 环境检查 nvidia-smiCUDA Version:12.4表示最高支持cuda 12.4版本 nvcc -V如图所示表示系统目前版本为cuda 12.2 2 多版本cuda下载与…

从零开始的LLaMA-Factory的指令增量微调

大模型相关目录 大模型&#xff0c;包括部署微调prompt/Agent应用开发、知识库增强、数据库增强、知识图谱增强、自然语言处理、多模态等大模型应用开发内容 从0起步&#xff0c;扬帆起航。 大模型应用向开发路径及一点个人思考大模型应用开发实用开源项目汇总大模型问答项目…

外卖项目:使用AOP切面,完成公共字段自动填充(断点调试详细讲解)

文章目录 一、问题描述二、实现思路三、实现步骤四、断点实操五、代码演示 一、问题描述 我们已经完成了后台系统的员工管理功能和菜品分类功能的开发&#xff0c;在新增员工或者新增菜品分类时需要设置创建时间、创建人、修改时间、修改人等字段&#xff0c;在编辑员工或者编…

Sentinel持久化(nacos)

导入依赖 <!--SpringCloud ailibaba sentinel-datasource-nacos --><dependency><groupId>com.alibaba.csp</groupId><artifactId>sentinel-datasource-nacos</artifactId></dependency> yml配置 rule-type: naco配置: resource&am…

javaweb遇到的servlet问题,jar包问题

有时候会遇到这种问题&#xff0c;有的地方会报红 这是因为这个找不到这个包&#xff0c;这个项目缺少jar包 在tomcat9之前还不是Jakarta这个名字&#xff0c;我的运行环境与服务器是jdk17与tomcat10 解决方法&#xff1a; 在项目结构中&#xff0c;找到模块&#xff0c;再…

踏“时间”与“空间”前来探寻复杂度的奥妙(Java篇)

本篇会加入个人的所谓‘鱼式疯言’ ❤️❤️❤️鱼式疯言:❤️❤️❤️此疯言非彼疯言 而是理解过并总结出来通俗易懂的大白话, 小编会尽可能的在每个概念后插入鱼式疯言,帮助大家理解的. &#x1f92d;&#x1f92d;&#x1f92d;可能说的不是那么严谨.但小编初心是能让更多人…

机器人路径规划:基于广度优先搜索算法的机器人路径规划(提供Python代码)

一、广度优先搜索算法简介 广度优先搜索&#xff08;BFS&#xff09;是一种用于图或树的遍历算法&#xff0c;它从根节点开始&#xff0c;逐层地向下搜索&#xff0c;直到找到目标节点或遍历完整个图。BFS使用队列数据结构来实现&#xff0c;保证了节点的访问顺序是按照层级逐…

拌合楼管理系统(八) c#海康威视摄像头车牌识别

前言: c#调用海康威视SDK实现车牌识别 原本以为海康威视sdk的Demo里面没有车牌识别的实例,后来发现自己肤浅了,官方是有提供的,只是车牌识别是通过安防布警的方式实现的.程序主动监听,触发告警后获取到车牌信息. 一、接口调用的流程&#xff1a; 首先初始化sdk -> 开…

PHP使用PHP_DIO读取串口数据

一、安装PHP_DIO扩展 1. 下载对应版本的dll扩展 根据你的操作系统类型选择对应的扩展名 PECL :: Package :: dio 下载地址&#xff1a; PECL :: Package :: dio 0.2.1 for Windows 以我使用的为例 我本地使用的是phpStudy PHP为7.4.3nts 64位的那就需要下载 注意你的是线程安全…

嵌入式学习42-数据结构-双向链表

知识散记&#xff1a; 1.程序使用时&#xff08;开闭原则&#xff09; …

iOS常见崩溃简介

1. 崩溃 多指在移动设备&#xff08;如iOS、Android设备&#xff09;中或不可移动设备&#xff08;如:Windows、Linux等设备&#xff09;&#xff0c; 在打开或使用应用程序时出现的突然退出中断的情况&#xff08;类似于Windows的应用程序崩溃&#xff09;。 多表现为&#…

全网最详细介绍如何实现图片存储阿里OSS实现资源持久化存储

什么是阿里云OSS 阿里云OSS&#xff08;Object Storage Service&#xff0c;对象存储服务&#xff09;是阿里云提供的一种存储服务&#xff0c;它支持任意类型的数据存储&#xff0c;如图片、视频、日志文件等。OSS以对象&#xff08;Object&#xff09;的形式组织数据&#x…

【导论】数据可信流通 从运维信任到技术信任

信任 信任概念由于其抽象性和结构复杂性&#xff0c;在社会学、心理学、营销学、经济学、管理学等不同 的领域定义是不同的&#xff0c;但是达成共识的观点是&#xff1a;信任是涉及交易或交换关系的基础。 信任的基石 ①身份可确认&#xff0c;②利益可依赖&#xff0c;③能…

docker实战(3)

1, jdk17版本的dockerfile FROM eclipse-temurin:17-jre ADD ./target/ods-poc-0.0.1-SNAPSHOT.jar /home/app/app.jar WORKDIR /home/app ENV TZ Asia/Shanghai ENTRYPOINT ["java","-jar","/home/app/app.jar"] EXPOSE 8083dockerfile 1, …

数据结构的概念大合集02(线性表)

概念大合集02 1、线性表及其逻辑结构1.1 线性表的定义1.2 线性表的基本操作 2、线性表的顺序存储结构2.1 顺序表 3、线性表的链式存储3.1 链表3.1.1 头结点&#xff08;头指针&#xff09;&#xff0c;首指针&#xff0c;尾指针&#xff0c;尾结点3.1.2 单链表3.1.3 双链表3.1.…