【LeetCode】相同的树、 翻转二叉树 、对称二叉树

news2024/9/20 16:35:40

100.相同的树

两棵树相同的条件就是根节点及他们的左右子树的值val相同,结构相同,就是一模一样,那这道题最终还是要同时遍历两个树的,并且还得遍历完,那如果我们在遍历的过程中,通过设置一些不满足相同的树的条件,那么只要遍历到不同的,就返回false。并且在每一次左右子树递归完成后就进行判断,(各自判断一次),如果不满足就不往下遍历了,否则,一直遍历。

不同的条件:左根为空并且右根不为空,或者,左根不为空并且右根为空,或者,左右根的值val不同。

 算法代码

class Solution {
    public boolean isSameTree(TreeNode p, TreeNode q) {
        if(p==null&&q==null) return true;  //说明本层遍历到末尾了,且本层是相同的树
        if(p==null&&q!=null || p!=null&&q==null || p.val != q.val) return false; //树不相同的全部条件
   
        boolean left = isSameTree(p.left,q.left);
        if(left == false) return false;  //返回fslse说明不相同,结束遍历,返回true则得继续遍历
        boolean right = isSameTree(p.right,q.right);
        if(right == false) return false;  //返回fslse说明不相同,结束遍历,返回true则得继续遍历
        return true;  //能执行到这里说明本层根节点及子树是相同的,再往上一层递归的归
    }
}

 

226.翻转二叉树

即从根节点开始,翻转根节点的左右子树,再以左孩子节点为当前根节点,翻转左孩子的左右子树,再以右孩子节点为当前根节点,翻转右孩子的左右子树.......依次往下递归,即就把每一个节点当成当前的根节点,再翻转它的左右子树,这样递归就形成了。(可以写一个交换函数)

 算法代码

class Solution {
    /*
    public TreeNode invertTree(TreeNode root) {
        if(root == null) return root; 
        exchange(root);  //交换函数
        invertTree(root.left);
        invertTree(root.right);
        return root;
    }
    public static void exchange(TreeNode root){ 
        TreeNode tmp = root.left;
        root.left = root.right;
        root.right = tmp;
    }
    */

    public TreeNode invertTree(TreeNode root) {
        if(root == null) return root; 
        TreeNode tmp = root.left; //临时节点,用来交换
        root.left = root.right;
        root.right = tmp;
        invertTree(root.left); //对根的左子树进行交换
        invertTree(root.right); //对根的右子树进行交换
        return root;
    }

}

 

572.另一棵树的子树

另一棵树的子树,实则还得判断root的的子树与subRoot相不相同,即可引用上面两棵相同的树的代码成为一个函数,判断相不相同,在遍历的时候,root树需要不断的往下遍历,而subRoot树只在root树与其(指SubRoot树)根节点相同的时候才再往下遍历。即函数传递节点的时候总是传递subRoot树的根节点。这点很重要。

 算法代码

class Solution {
    public boolean isSubtree(TreeNode root, TreeNode subRoot) {
        //第一种
        /*
        if(isSameTree(root,subRoot)==true)  return true; //  归的条件
        if(root==null ) return false;                    //  归的条件
        return isSubtree(root.left,subRoot) || isSubtree(root.right,subRoot);  //不断的递
        */
        
        //第二种
        /*
        if(root==null ) return false;
        if(isSameTree(root,subRoot)==true)  return true;
        if(isSubtree(root.left,subRoot)==true)  return true;
        if(isSubtree(root.right,subRoot)==true)  return true;
        return false;
        */
    }

    public static boolean isSameTree(TreeNode p, TreeNode q) {  //借用相同的树的代码
        if(p==null&&q==null) return true;
        if(p==null&&q!=null || p!=null&&q==null || p.val != q.val) return false;
   
        boolean left = isSameTree(p.left,q.left);
        if(left == false) return false;
        boolean right = isSameTree(p.right,q.right);
        if(right == false) return false;
        return true;
    }
}

 

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

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

相关文章

【知识图谱】图数据库Neo4jDesktop的安装图文详解(小白适用)

neo4j 的安装需要有jdk环境的支持。因此在安装Neo4j之前,需要安装Java JDK。 一.安装JDK 参考文章https://blog.csdn.net/weixin_41824534/article/details/104147067?spm1001.2014.3001.5502 二.Neo4j下载 进入Neo4j官网 选择下载中心 下滑选择Neo4j Deskto…

Python渗透测试编程——AES与DES算法

一、AES简介 AES(Advanced Encryption Standard,高级加密标准)的出现,是因为以前使用的DES算法密钥长度较短,已经不适应当今数据加密安 全性的要求,因此2000年10月2日,美国政府宣布将比利时密码…

多雷达协同探测技术研究进展:认知跟踪与资源调度算法

源自:雷达学报 作者:易伟 袁野 刘光宏 葛建军 孔令讲 杨建宇 1. 引 言 雷达是信息感知的千里眼,具有极高的军用和民用价值,广泛应用在防空预警、遥感测绘、反恐维稳等领域[1–5]。雷达信息获取与探测技术也一直是大国竞相抢占…

window中,关闭java占用端口的进程

查看端口被占用的情况 netstat -ano|findstr "端口号"使用Tasklist查看对于 PID 的进程名 tasklist|findstr "PID号"通过 taskkill 命令方式结束进程 taskkill /f /t /im Pid

更新k8s环境支付系统支付证书

目录 一、背景 二、更新支付系统银行证书 三、备份旧的secret信息 四、更新支付应用的证书信息 五、重启支付系统的应用 六、验证应用实例挂载的秘钥已更新 一、背景 支付系统是基于k8s容器化部署的微服务,支付系统使用的支付证书以及和银行有关的证书都是保存…

SpringBoot中事务失效的原因

SpringBoot中事务失效的原因 文章目录 SpringBoot中事务失效的原因一、事务方法非public修饰二、非事务方法调用事务方法三、事务方法的异常被捕获四、事务异常类型不对五、事务传播行为不对六、没有被Spring管理6.1、暴漏代理对象6.2、使用代理对象 常见的事务失效原因包括如下…

《Flask Web 开发指南 pt.2》

在编写 Flask 程序的时候,你需要注意你的程序文件不要命名为 flask.py,建议命名为 app.py 或者 wsgi.py 但如果你的程序不是叫 app.py 或者 wsgi.py,那么你就需要设置环境变量 FLASK_APP 的值为程序名字 设置环境变量有两种方法,在…

聚观早报 | 腾讯字节等企业驰援防汛救灾;新能源车7月销量单出炉

【聚观365】8月4日消息 腾讯字节等企业驰援防汛救灾新能源车7月销量成绩单出炉Model Y等车型低温续航衰减严重华为Mate60系列猜想图曝光支付宝做短视频引来羊毛党 腾讯字节等企业驰援防汛救灾 近日,京津冀地区遭遇极端降雨天气,引发洪涝和地质灾害&…

智能仪表板DevExpress Dashboard v23.1亮点 - 增强对自定义导出的支持

DevExpress Dashboard v23.1版本增强了自定义导出到Excel的功能等,欢迎下载最新版本体验! DevExpress Dashboard v23.1正式版下载(Q技术交流:523159565) 所有平台 导出自定义仪表板项目到Excel 用户现在可以在WinForms和Web应…

吴新宙「跳槽」背后,是英伟达全栈智能汽车方案的「野心」

8月2号晚,小鹏汽车CEO何小鹏发文:因家庭和多方面的原因,小鹏汽车自动驾驶副总裁吴新宙将离开公司。同时也确定了吴新宙下一站:知名公司(英伟达)最高等级华人高管。 事实上,在过去的五年时间里&a…

科技引领,教育革新|EasyV助力数字孪生智慧教育建设!

数字孪生校园是以物联网、大数据、云计算、人工智能、三维可视化等新型数字化技术为基础,构建的数智校园的“大脑”。对校园的人、车、资产设施、各业务系统进行全联接,实现数据全融合、状态全可视、业务全可管、事件全可控,使校园更安全、更…

微信认证申请流程(媒体类型)

第一步:登录微信公众平台->设置->微信认证->开通 第二步:同意协议:签署《微信公众平台认证服务协议》 第三步:验证管理员 第四步:选择认证类型及填写认证资料 选择认证类型及上传申请公函 媒体资质信息 对公…

Gradle-02:问题Plugin with id ‘maven‘ not found

1. 背景 在一次使用 Gradle 构建自己项目,完事,需要上传到本地 Maven 仓库,因为事先并不清楚 apply plugin: maven 插件已经被 Gradle 移除,找了一圈,才找到解决方案。 2. 原因 apply plugin: maven def localRepo f…

Docker实战-关于Docker镜像的相关操作(一)

导语   镜像,Docker中三大核心概念之一,并且在运行Docker容器之前需要本地存储对应的镜像。那么下面我们就来介绍一下在Docker中如何使用镜像。 如何获取镜像? 镜像作为容器运行的前提条件,在Docker Hub上提供了各种各样的开放的…

项目进度管理软件可以解决哪些难题?

项目进度管理是在项目实施过程中,对各阶段的进展程度和项目最终完成的期限所进行的管理。它以确保项目能在满足其时间约束条件的前提下实现其总体目标。 项目进度管理软件可以解决以下难题: 一、进度跟踪 如果没有完善的进度计划,项目很难…

【计算机视觉 | Kaggle】飞机凝结轨迹识别 Baseline 分享和解读(含源代码)

文章目录 一、导读二、比赛背景三、比赛任务四、比赛数据五、评价指标六、Baseline6.1 Training part6.2 Submission part 一、导读 比赛名称:Google Research - Identify Contrails to Reduce Global Warming https://www.kaggle.com/competitions/google-researc…

一、单片机_RTOS_架构

1、RTOS的概念 RTOS是实时操作系统(Real-Time Operating System)的缩写。它是一种专门为实时应用程序设计的操作系统,具有实时性、高可靠性和紧凑性等特性。RTOS可以在嵌入式系统、工业自动化、航空航天、科学仪器等领域应用,主要…

HTML 基础标签

前言 当今互联网时代&#xff0c;网页是我们获取信息、交流和展示自己的重要渠道之一。而HTML&#xff08;超文本标记语言&#xff09;作为构建网页的基础&#xff0c;学习掌握HTML标签成为了必不可少的技能。 标题标签 <h1>~<h6>&#xff1a;这是用来定义标题的…

基于arcFace+faiss开发构建人脸识别系统

在上一篇博文《基于facenetfaiss开发构建人脸识别系统》中&#xff0c;我们实践了基于facenet和faiss的人脸识别系统开发&#xff0c;基于facenet后续提出来很多新的改进的网络模型&#xff0c;arcFace就是其中一款优秀的网络模型&#xff0c;本文的整体开发实现流程与前文相同…

vCenter Server Appliance(VCSA )7.0 部署指南

部署准备 1、下载VMware-VCSA-all-7.0.0-xxxx.iso文件&#xff0c;用虚拟光驱挂载或者解压运行&#xff0c;本地系统以win10拟光驱挂载为例&#xff0c;运行vcsa-ui-installer/win32/installer.exe。 2、选择“安装”&#xff0c;VCSA 7.0版本同时提供其他选项。 第一阶段 3、…