二叉树OJ题(检查两颗数是否相同、另一棵树的子树、翻转二叉树、判断平衡二叉树)

文章目录

  • 二叉树OJ题
    • 一、 检查两颗数是否相同
      • 1.思路
      • 2.解题步骤
      • 3.代码
    • 二、另一棵树的子树
      • 1.思路
      • 2.代码
    • 三、翻转二叉树
      • 1.思路
      • 2.解题步骤
      • 3.代码
    • 四、判断平衡二叉树

二叉树OJ题


一、 检查两颗数是否相同

在这里插入图片描述

1.思路

1.两个树,在保证结构相同的同时,结点的值也要相同

2.一个为空一个不为空,结构不同。都为空,结构相同。都不为空,判断值是否相同

3.先判断根节点是否一样

4.再判断左树是否一样,然后判断右树

2.解题步骤

  • 1.判断两棵树的结构是否相同
  • 2.如果一个结点为空,一个结点不为空,则证明结构不一致,直接返回false
  • 3.结构一致说明都为空,或者都不为空,都不为空包括值相同和值不同两种情况,都为空返回false
  • 4.如果都不为空并且值不同,返回ture
  • 5.到此,判断好了根节点的情况,先递归左子树,左子树判断完,再递归右子树进行判断
  • 6.最后返回,两个子树取到的返回值相与,出现false则返回false
  • 时间复杂度:o(min(m,n))
  • 空间复杂的:o (min(m,n))

3.代码

    //判断两棵树是否相同public static boolean isSameTree(TreeNode p, TreeNode q) {if (p == null && q != null || p != null && q == null) {return false;//保证结构相同}//要么都是空,要么都不是空if (p == null && q == null) {return true;//结点都为空,结构一样}if (p.val != q.val) {return false;//结构一样的情况下,值也要相同}//pq都不空且根节点的值都相同return isSameTree(p.left, q.left) && isSameTree(p.right, q.right);//递归得到左右子树返回回来的值}

二、另一棵树的子树

在这里插入图片描述

1.思路

0.需要调用刚写的判断两棵树是否相同

1.判断两个树是否完全相同

2.不相同,判断是不是和左子树相同

3.再判断是不是和右子树相同

4.都不相同,返回false

5.当root等于空时返回false,避免发生空指针异常

2.代码

    //判断两棵树是否相同public  boolean isSameTree(TreeNode p, TreeNode q) {if (p == null && q != null || p != null && q == null) {return false;//保证结构相同}//要么都是空,要么都不是空if (p == null && q == null) {return true;//结点都为空,结构一样}if (p.val != q.val) {return false;//结构一样的情况下,值也要相同}//pq都不空且根节点的值都相同return isSameTree(p.left, q.left) && isSameTree(p.right, q.right);//递归得到左右子树返回回来的值}//另一棵树的子树public boolean isSubtree(TreeNode root, TreeNode subRoot) {if (root == null){return false;//避免空指针异常}if ( isSameTree(root,subRoot)){return true;//先判断两个树是否完全一样}if (isSubtree(root.left,subRoot)){return true;//判断是不是和左子树相同}if (isSubtree(root.right,subRoot)){return true;//判断是不是和右子树相同}return false;//没有找到,返回false}
  • 时间复杂度:o ( s * t )
  • 空间复杂度:o (Max (ds , dt ))

三、翻转二叉树

在这里插入图片描述

1.思路

1.翻转整棵树

2.先把根节点的左子树和右子树交换

3.再交换子树上的子树

2.解题步骤

  • 先判断该树是否为空
  • 不为空,用tmp存储左孩子
  • 交换根结点的左子树和右子树
  • 先交换左子树中的左右子树,再交换右子树当中的
  • 最后翻转完成,返回根结点

3.代码

    //翻转二叉树public TreeNode invertTree(TreeNode root) {if (root == null){return null;}TreeNode tmp = root.left;//根节点的左右树进行交换root.left = root.right;root.right = tmp;invertTree(root.left);//交换左子树中的子树invertTree(root.right);//交换右子树中的子树return root;}

四、判断平衡二叉树

在这里插入图片描述

1.思路

1.每个结点都要判断左右子树的高度差的绝对值不超过 1 。也就是说: | 高度差 |<2

2.root为空,返回true

3.左右子树的高度差要小于2

4.左右子树都要保存平衡

2.代码

class Solution {//判断平衡二叉树public boolean isBalanced(TreeNode root) {if (root == null) {return true; //为空,返回true}int leftHeight = maxDepth(root.left);//得到左子树的高度int rightHeight = maxDepth(root.right);//得到右子树的高度return Math.abs(leftHeight - rightHeight) < 2//左右树高度差的绝对值<2&& isBalanced(root.left) && isBalanced(root.right);//并且满足左右子树都是平衡的}public int maxDepth(TreeNode root){//求高度if(root == null){return 0;}int leftHeight = maxDepth(root.left);int rightHeight = maxDepth(root.right);return leftHeight>rightHeight?leftHeight+1:rightHeight+1;}
}
  • 时间复杂度:o ( n2 ) :求高度的时间复杂度o(n),有n个结点,所以时间复杂度为 n2

如何改成时间复杂度为 o(n)?

1.在求左右树高度的时候,会重复求子树的高度,子树的高度是不断递归返回上来的和,

2.求一个子树的高度时,已经计算过一遍它子树的子树高度,重复计算

3.也就是说,在之前求高度的时候,高度可能已经不平衡了,但是返回的是最大值+1,没有考虑度差的绝对值<2的情况

4.所以可以再求高度的时候,就判断高度差,不平衡直接返回,避免再重复计算

    public boolean isBalanced(TreeNode root) {return maxDepth(root)>=0;//只需要判断返回的值是否>=0}public int maxDepth(TreeNode root){//求高度if(root == null){return 0;}int leftHeight = maxDepth(root.left);if(leftHeight<0){//如果左子树有返回-1的值,说明有不平衡的情况return -1;//不用进入右子树了,直接返回}int rightHeight = maxDepth(root.right);if(rightHeight<0){//如果右子树出现-1,直接返回,不用进行后面的运算return -1;}if(Math.abs(leftHeight-rightHeight)<2){//求高度的时候就判断高度差return Math.max(leftHeight,rightHeight)+1;//符合返回最大值+1}else {return -1;//不符合返回-1;}} }

经过改进,时间复杂度从o ( n2 ) 降到了o(n)。

点击移步博客主页,欢迎光临~

偷cyk的图

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

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

相关文章

iOS 使用dsym符号化线上crash日志(ips文件)

1.获取崩溃日志 可以iphone连接mac复制当时的崩溃日志。 Xcode->Window->Devices View Device Logs 如果是testflight的崩溃是可以分享的&#xff0c;分享出来可能是ips文件。 把文件名称改成my.crash 使用脚本把新版本崩溃日志转成老版本格式 这一步不是必须的&…

如何知道服务器的某个端口是否打开

注意&#xff1a;服务器的TCP端口&#xff0c;比如1886端口&#xff0c;出方向 和进方向 都打开才可以用 1、telnet 命令&#xff1a;telnet ip port&#xff0c;port即端口&#xff0c;我们一般最常见的命令就是telnet&#xff0c;但是telnet使用的是tcp协议&#xff0c;换句…

[云原生案例1.] 构建LNMP架构并运行Wordpress个人博客平台

文章目录 1. 当前需求2. 前置准备3. 搭建过程3.1 创建自定义网络3.2 部署并配置nginx3.2.1 创建工作目录并上传相关软件包3.2.2 解压缩相关软件包3.2.3 编写Dockerfile文件3.2.4 编写nginx.conf文件3.2.5 创建nginx镜像3.2.6 运行容器 3.3 部署并配置mysql3.3.1 创建工作目录3.…

在科技展厅设计中,如何通过空间规划来突出展品和主题?

数字多媒体技术在各行业内的广泛应用&#xff0c;使内容展览展示技术得到了更新&#xff0c;尤其是在科技展厅设计中&#xff0c;更是将各类多媒体互动装置的优势发挥到了极致&#xff0c;为观众提供现代化的感官体验&#xff0c;而这其中有效的空间规划对于现代化科技展厅的效…

3D模拟场景开发引擎

在3D工程模拟开发中&#xff0c;有一些专门的引擎和工具可供选择&#xff0c;以帮助您创建逼真的三维模拟和模型。以下是一些用于3D工程模拟的开发引擎和工具&#xff0c;希望对大家有所帮助。北京木奇移动技术有限公司&#xff0c;专业的软件外包开发公司&#xff0c;欢迎交流…

最新Ubuntu20.04安装教程(图文)

总的来说&#xff0c;安装Ubantu包含以下三个步骤&#xff1a; 一、安装虚拟机 二、Ubuntu镜像下载 三、虚拟机配置 一、安装虚拟机 选择安装VMware Workstation&#xff0c;登录其官网下载安装包&#xff0c;链接如下&#xff1a; 下载 VMware Workstation Pro | CN 下载…

iOS实现弹簧放大动画

效果图 实现代码 - (void)setUpContraints {CGFloat topImageCentery (SCREEN_HEIGHT - 370 * PLUS_SCALE) / 2;[self.topIconView mas_makeConstraints:^(MASConstraintMaker *make) {make.centerX.mas_equalTo(0);make.centerY.equalTo(self.view.mas_top).with.offset(t…

面试官:聊聊kafka线上使用会有哪些问题?

哪些环节会造成消息丢失&#xff1f; 首先说说哪些环节会丢消息 消息生产者&#xff1a; &#xff08;1&#xff09;acks0&#xff1a; 表示producer不需要等待任何broker确认收到消息的回复&#xff0c;就可以继续发送下一条消息。性能最高&#xff0c;但是最容易丢消 息。大…

关键点检测、姿态识别、目标检测、车牌识别等项目部署代码+数据集汇总

一、AI健身计数 1、图片视频检测 &#xff08;cpu运行&#xff09;&#xff1a; 注&#xff1a;左上角为fps&#xff0c;左下角为次数统计。 1.哑铃弯举&#xff1a;12&#xff0c;14&#xff0c;16 详细环境安装教程&#xff1a;pyqt5AI健身CPU实时检测mediapipe 可视化界面…

VS LiveShare使用操作介绍

VS LiveShare的使用教程 文章简介下载过程 文章简介 本篇文章主要介绍了如何安装和使用LiveShare的过程。 下载过程 1.在扩展->管理扩展&#xff0c;搜索Live Share后&#xff0c;下载对应的安装包&#xff0c;安装后对VS进行重启 2.安装后界面右上角会出现Live Share标…

docker环境安装+maven依赖继承问题

1&#xff0c;docker环境安装 我们使用yum指令进行安装&#xff0c;分别cmd运行&#xff1a; yum install -y yum-utils device-mapper-persistent-data lvm2 yum-contig-manager --add-repo https://download.docker.com/linux/centos/docker-ce.rep具体解释如下&#xff1a;…

目标检测中常见指标 - mAP

文章目录 1. 评价指标2. 计算示例3. COCO评价指标 1. 评价指标 在目标检测领域&#xff0c;比较常用的两个公开数据集&#xff1a;pascal voc和coco。 目标检测与图像分类明显差距是很大的&#xff0c;在图像分类中&#xff0c;我们通常是统计在验证集当中&#xff0c;分类正…

【Azure】存储服务:Azure 的存储账户

文章目录 一、前提知识&#xff08;建议了解&#xff09;二、介绍 Azure 存储帐户三、使用 Microsoft Azure 门户创建存储帐户 一、前提知识&#xff08;建议了解&#xff09; 在每一个云厂商中&#xff0c;都有自身的云存储&#xff0c;也有根据不同功能进行区分的不同类型的…

SPSS两独立样本t检验

前言&#xff1a; 本专栏参考教材为《SPSS22.0从入门到精通》&#xff0c;由于软件版本原因&#xff0c;部分内容有所改变&#xff0c;为适应软件版本的变化&#xff0c;特此创作此专栏便于大家学习。本专栏使用软件为&#xff1a;SPSS25.0 本专栏所有的数据文件请点击此链接下…

循环神经网络(RNN)与长短期记忆网络(LSTM)

前言&#xff1a; 通过前面的学习&#xff0c;我们以BP神经网络为基础&#xff0c;认识到了损失函数&#xff0c;激活函数&#xff0c;以及梯度下降法的原理&#xff1b;而后学习了卷积神经网络&#xff0c;知道图像识别是如何实现的。今天这篇文章&#xff0c;讲述的就是计算机…

【Linux】第七站:vim的使用以及配置

文章目录 一、vim1.vim的介绍2.vim基本使用3.vim的命令模式常用命令4.底行模式 二、vim的配置 一、vim 1.vim的介绍 vim编辑器&#xff0c;用来文本编写&#xff0c;可以写代码 它是一个多模式的编辑器 它有很多的模&#xff0c;不过我们暂时先只考虑这三种模式 命令模式插入模…

v-bind动态改变样式

通过v-bind切换样式&#xff0c;:class"{ active:true}"为true展示样式&#xff0c;false不展示。也可以由:style"{ width:percent %}"动态控制宽度。 注意后面是JS对象&#xff0c;所以后面的值不可以包含-&#xff0c;比如background-color会解析出错&a…

Windows下多Chrome谷歌浏览器版本共存

场景 某些年代久远的 WEB 应用&#xff0c;必须在指定的浏览器或版本才能正常运行&#x1f602;&#xff0c;此时就需要多个版本 chrome 浏览器共存。 解决方案 下载指定版本 可以从 https://www.chromedownloads.net/ 下载需要的版本&#xff0c;此处下载的是87.0.4280.14…

C++之string

C之string #include <iostream>using namespace std;/*string();//创建一个空的字符串string(const char* s);//使用字符串s初始化string(const string& str);//使用一个string对象初始化另外一个string对象string(int n,char c);//使用n个字符c初始化*/void test1()…

带你从0开始学习自动化框架Airtest

现在市面上做UI自动化的框架很多&#xff0c;包括我们常用的Web自动化框架Selenium&#xff0c;移动端自动化框架Appium。 虽然Selenium和Appium分属同源&#xff0c;而且API都有很多相同的地方&#xff0c;可以无损耗切换&#xff0c;但是还是需要引入不同的库&#xff0c;而…