代码随想录刷题笔记 DAY15 | 翻转二叉树 No.226 | 对称二叉树 No.101

Day 15

01. 翻转二叉树(No. 226)

题目链接

代码随想录题解

1.1 题目

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

示例 1:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

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

示例 2:

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

示例 3:

输入:root = []
输出:[]

提示:

  • 树中节点数目范围在 [0, 100]
  • -100 <= Node.val <= 100
1.2 笔记

一道考察递归遍历的题目,我们要先理清这道题目的要求

题目要求我们的是交换二叉树的节点,注意不是交换值,所以我们要在递归遍历的时候去交换节点,递归遍历分为前序、中序和后序,我们只需要在遍历到节点的期间去交换节点即可。

下面我们以前序为例子:

和上面提到的相同,前序遍历就是在进入节点的时候立刻进行的操作,我们在进入节点前交换左右子树,和上一节博客讲的一样,对所有的节点进行相同的处理,即可完成交换

后序遍历也是同理。

但是中序遍历是不行的,中序遍历是在左子树返回的时候进行交换,我们看看会有什么后果:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

比如我们这里把左子树处理完了

这时候我们中序回到根节点,将 2 和 7 一交换再去递归右边,这不是就完全恢复了吗?

就相当于我们只交换了根节点下面的两个节点,其他是没变化的

写到这里就可以给出代码了

1.3 代码
class Solution {public TreeNode invertTree(TreeNode root) {traverse(root);return root;}public void traverse(TreeNode root) {// 递归出口if (root == null) {return;}// 交换节点TreeNode temp = root.left;root.left = root.right;root.right = temp;traverse(root.left);traverse(root.right);}
}

02. 对称二叉树(No. 101)

题目链接

代码随想录题解

2.1 题目

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

示例 1:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

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

示例 2:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

输入:root = [1,2,2,null,3,null,3]
输出:false

提示:

  • 树中节点数目在范围 [1, 1000]
  • -100 <= Node.val <= 100
2.2 笔记

这道题我们要理解后序遍历的特殊性,后序遍历是在遍历完子节点后返回时做的操作,这就意味着我们可以 收集到子节点的信息,所以后序遍历经常用在需要子节点信息的情况。

这道题我们要比较内侧和外侧的信息,我们如何遍历这个树的外侧呢?

回顾一下我们写的二叉树遍历的代码:

public void reverse(TreeNode node) {reverse(node.right);reverse(node.left);
}

我们对每个节点进行的操作是遍历 左子树 和 右子树,但如果我们要求的只是遍历外侧,也就是说只遍历 左节点的左节点和右节点的右节点:

public void reverse(Treenode right) {reverse(node.right);
}

public void reverse(Treenode left) {reverse(node.left);
}

这便是遍历树的外侧,抛去二叉树的外壳,这其实就是链表的递归遍历

接下来我们将这两个方向的遍历合在一起

    public boolean isSymmetric(TreeNode root) {return compare(root.left, root.right);}public boolean compare(TreeNode left, TreeNode right) {if (left == null && right != null) {return false;}if (right == null && left != null) {return false;}if (right == null && left == null) {return true;}if (right.val != left.val) {return false;}boolean compareOutside = compare(left.left, right.right);return compareOutside;
}

上述的代码就是将根节点的左右节点分别传入,对左节点只进行向左的递归,对右节点只进行向右的递归,注意我们返回结果的位置正是说的后序的位置,因为只有这个位置才是验证完成 子节点 的对称性并且返回的的位置。

这个位置可以理解为我们 收集信息 的位置,如果对理解递归有困难的话,我们可以想象有一个外置的 boolean flg 全局变量,当我们一旦发现 左右不对称的时候,也就是我们的 compare(left.left, right.right); 返回值为 false 的时候,就将这个 flg 设置为 false,实际上这和递归实现的效果是相同的。

那对于内侧的遍历也很好写出来了:

class Solution {public boolean isSymmetric(TreeNode root) {return compare(root.left, root.right);}public boolean compare(TreeNode left, TreeNode right) {if (left == null && right != null) {return false;}if (right == null && left != null) {return false;}if (right == null && left == null) {return true;}if (right.val != left.val) {return false;}boolean compareInside = compare(left.right, right.left);return compareInside;}
}

内侧就是首先传入根节点的 左子树,对左子树向右递归遍历,以及对右子树向左递归遍历

将这两段代码整合起来,就变成了这道题的解答

2.3 代码
/*** Definition for a binary tree node.* public class TreeNode {*     int val;*     TreeNode left;*     TreeNode right;*     TreeNode() {}*     TreeNode(int val) { this.val = val; }*     TreeNode(int val, TreeNode left, TreeNode right) {*         this.val = val;*         this.left = left;*         this.right = right;*     }* }*/
class Solution {public boolean isSymmetric(TreeNode root) {return compare(root.left, root.right);}public boolean compare(TreeNode left, TreeNode right) {if (left == null && right != null) {return false;}if (right == null && left != null) {return false;}if (right == null && left == null) {return true;}if (right.val != left.val) {return false;}boolean compareOutside = compare(left.left, right.right);boolean compareInside = compare(left.right, right.left);return compareInside && compareOutside;}
}

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

PCB制板基础知识

一、PCB概念 PCB&#xff08;PrintedCircuitBoard&#xff09;&#xff0c;中文名称为印制电路板&#xff0c;又称印刷电路板、印刷线路板&#xff0c;是重要的电子部件&#xff0c;是电子元器件的支撑体&#xff0c;是电子元器件电气连接的提供者。由于它是采用电子印刷术制作…

使用vs2022将.net8的应用程序发布为一个单独文件

在使用.NetCore3.1时&#xff0c;可以通过设置以下工程配置文本来将项目发布为一个单独的应用程序文件&#xff1a; <Project Sdk"Microsoft.NET.Sdk.WindowsDesktop"><PropertyGroup><TargetFramework>netcoreapp3.1</TargetFramework><…

Python open函数

在Python编程中&#xff0c;open()函数是一个重要的文件操作函数&#xff0c;用于打开文件并进行读取、写入、追加等操作。本文将深入探讨open()函数的用法、语法、文件模式、示例代码&#xff0c;并探讨其在实际编程中的应用场景。 什么是open()函数&#xff1f; open()函数…

机房及设备安全智慧监管AI+视频方案的设计和应用

一、背景分析 随着互联网的迅猛发展&#xff0c;机房及其配套设施的数量持续攀升&#xff0c;它们的运行状况对于企业运营效率和服务质量的影响日益显著。作为企业信息化的基石&#xff0c;机房的安全监测与管理的重要性不容忽视。它不仅关乎企业的稳定运营&#xff0c;同时也…

《WebKit技术内幕》学习之十五(3): Web前端之未来

3 Web应用和Web运行环境 3.1 Web应用 HTML5提供了强大的能力&#xff0c;而不是支持Web网页这么简单。就目前而言&#xff0c;它已经初步提供了支持Web网页向Web应用方向发展的能力。相对于本地应用&#xff08;Native Application&#xff09;&#xff0c;Web前端领域也能够…

Android Gradle Sync Task list is empty

问题 有时候 Android studio 打开项目&#xff0c;可能会遇到构建没有明显报错&#xff0c;但是 Gradle 却没有 Task list&#xff0c;或者 Task list 不完整只有零星几个配置项。连打包任务都没有&#xff0c;我怎么打包&#xff01; 异常情况&#xff1a; 正常情况&#xf…

IDEA jdk版本切换问题

打开 IntelliJ IDEA 的 Project Structure&#xff08;快捷键通常是 Ctrl Alt Shift S&#xff09;。 转到 Project Settings > Modules。 选择相应的模块&#xff0c;然后在 Sources 标签页下&#xff0c;查看 Language level 是否设置为 自己需要的jdk版本语言。 接…

Kotlin Multiplatform项目推荐 | 太空人分布图

Kotlin Multiplatform项目推荐 | 太空人分布图 项目简介 Kotlin Multiplatform项目是一种跨平台开发技术&#xff0c;它可以同时使用SwiftUI、Jetpack Compose、Compose for Wear OS、Compose for Desktop、Compose for Web、Kotlin/JS React等客户端框架&#xff0c;并且使…

C# 设置一个定时器函数

C#中&#xff0c;创建设置一个定时器&#xff0c;能够定时中断执行特定操作&#xff0c;可以用于发送心跳、正计时和倒计时等。 本文对C#的定时器简单封装一下&#xff0c;哎&#xff0c;以方便定时器的创建。 定义 using Timer System.Timers.Timer;class SetTimer {Timer …

【C++】list讲解及模拟

目录 list的基本介绍 list模拟实现 一.创建节点 二.迭代器 1.模版参数 2.迭代器的实现&#xff1a; a. ! b. c. -- d. *指针 e.&引用 整体iterator (与const复用)&#xff1a; 三.功能实现 1.模版参数 2.具体功能实现&#xff1a; 2.1 构造函数 2.2 begi…

antv/x6自定义节点+小地图+复制/删除节点+拖拽生成节点

1、 下载x6&#xff1a; npm i antv/x62.17.1 同步下载所需要用到的x6插件&#xff1a; "antv/x6-plugin-clipboard": "^2.0.0", // 如果使用剪切板功能&#xff0c;需要安装此包 "antv/x6-plugin-history": "^2.0.0", // 如果使用撤销…

链表--543. 二叉树的直径/medium 理解度C

543. 二叉树的直径 1、题目2、题目分析3、复杂度最优解代码示例4、适用场景 1、题目 给你一棵二叉树的根节点&#xff0c;返回该树的 直径 。 二叉树的 直径 是指树中任意两个节点之间最长路径的 长度 。这条路径可能经过也可能不经过根节点 root 。 两节点之间路径的 长度 …