力扣第572题 另一棵树的子树 c++深度(DFS)注释版

news2024/10/6 8:40:07

题目

572. 另一棵树的子树

简单

给你两棵二叉树 root 和 subRoot 。检验 root 中是否包含和 subRoot 具有相同结构和节点值的子树。如果存在,返回 true ;否则,返回 false 。

二叉树 tree 的一棵子树包括 tree 的某个节点和这个节点的所有后代节点。tree 也可以看做它自身的一棵子树。

示例 1:

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

示例 2:

输入:root = [3,4,5,1,2,null,null,null,null,0], subRoot = [4,1,2]
输出:false

提示:

  • root 树上的节点数量范围是 [1, 2000]
  • subRoot 树上的节点数量范围是 [1, 1000]
  • -104 <= root.val <= 104
  • -104 <= subRoot.val <= 104

思路和解题方法

  1. bool check(TreeNode *o, TreeNode *t):这个函数检查两个节点是否相同,o表示s的节点,t表示t的节点。该函数使用递归方法判断两个节点是否相同,如果它们的值相等并且左右子树也相等,则返回true,否则返回false

  2. if(!o && !t):如果st都为空,则true,这意味着ts的子树。

  3. if((o&&!t)||(!o&&t)||(o->val!=t->val)):如果只有o或只有t为空,或者它们的值不相等,这说明t不能是子树,返回false

  4. return check(o->left,t->left)&&check(o->right,t->right):如果它们的值相等,并且左右子树也相等,则返回true。该函数的返回方式是通过递归调用自己进行判断的。

  5. bool dfs(TreeNode *o, TreeNode *t):该函数使用递归,沿着s向下遍历所有节点。如果在某个节点的子树中存在t,则返回true。如果整个树都遍历完了,还没有发现任何t的子树,则返回false

  6. return check(o,t)|| dfs(o->left,t)||dfs(o->right,t):用于判断当前节点是否为t的子树,如果是,则返回true。如果不是,则递归调用此函数来遍历s的左右子树。如果任何一个子树包含t,则返回true,否则返回false

  7. bool isSubtree(TreeNode *s, TreeNode *t):该函数是该算法的入口,它接受两个参数st,分别表示主树和子树。它使用深度优先搜索遍历s上的每个节点,并调用dfscheck函数来检查t是否是s的子树。如果ts的子树,则返回true,否则返回false

复杂度

        时间复杂度:

                O(m*n)

  • check函数的时间复杂度是O(n),其中n是树的节点数,因为最坏情况下需要比较所有节点的值。
  • dfs函数的时间复杂度是O(m*n),其中m是主树的节点数,n是子树的节点数。因为在最坏情况下,需要遍历主树的每个节点,并调用check函数进行比较。

所以总体上,算法的时间复杂度可以表示为O(m*n),其中m是主树的节点数,n是子树的节点数。

        空间复杂度

                O(n)

  • 空间复杂度由递归调用造成的函数调用栈占用的空间决定。在最坏情况下,树的高度可以达到n,所以空间复杂度是O(n)。

c++ 代码

class Solution {
public:
    // 检查两个节点是否相同
    bool check(TreeNode *o, TreeNode *t) {
        if (!o && !t) return true;  // 如果都为空,则返回true
        if ((o && !t) || (!o && t) || (o->val != t->val)) return false; // 如果其中一个为空或值不相等,则返回false
        return check(o->left, t->left) && check(o->right, t->right); // 递归调用自己比较左右子树是否相等
    }

    // 深度优先搜索遍历主树,判断是否存在子树t
    bool dfs(TreeNode *o, TreeNode *t) {
        if (!o) return false; // 如果o为空树,则不存在子树t
        return check(o, t) || dfs(o->left, t) || dfs(o->right, t); // 判断当前节点是否为子树,如果不是,则递归地遍历左右子树
    }

    // 判断是否为子树
    bool isSubtree(TreeNode *s, TreeNode *t) {
        return dfs(s, t);
    }
};

觉得有用的话可以点点赞,支持一下。

如果愿意的话关注一下。会对你有更多的帮助。

每天都会不定时更新哦  >人<  。

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

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

相关文章

ES6 class类关键字super

super关键字 在 JavaSCript 中&#xff0c;能通过 extends 关键字去继承父类 super 关键字在子类中有以下用法&#xff1a; 当成函数调用 super() 作为 "属性查询" super.prop 和 super[expr] super() super 作为函数调用时&#xff0c;代表父类的构造函数。 ES6 要求…

如何设计一条大型PLC生产线系统

今日话题&#xff0c;如何设计一条大型PLC生产线系统&#xff0c;设计一条大型PLC生产线系统实际上涉及通用系统设计的问题。以机床为例&#xff0c;它的核心架构包括数控面板和多台伺服机&#xff0c;这些伺服机具有很强的通用性&#xff0c;它们作为从站响应数控面板的信号。…

在原生html中使用less

引入less <link rel"stylesheet/less" href"./lessDemo.less" /><script src"./js/less.min.js"></script> less.min.js文件下载地址:https://github.com/less/less.js 注意&#xff1a;less文件在前&#xff0c;js文件在后…

Langchain-Chatchat项目:1-整体介绍

基于Langchain与ChatGLM等语言模型的本地知识库问答应用实现。项目中默认LLM模型改为THUDM/chatglm2-6b[2]&#xff0c;默认Embedding模型改为moka-ai/m3e-base[3]。 一.项目介绍 1.实现原理   本项目实现原理如下图所示&#xff0c;过程包括加载文件->读取文本->文本…

记一个src中危-图像大小与请求参数可修改

公众号&#xff1a;掌控安全EDU 分享更多技术文章&#xff0c;欢迎关注一起探讨学习 漏洞描述 服务器生成了一个具有客户端指定尺寸的图像&#xff0c;如果未实施任何限制&#xff0c;则可能导致拒绝服务攻击。 漏洞危害 攻击者不需要在此类攻击中投入资源&#xff0c;但服务器…

迅为RK3588开发板添加 RIL 驱动程序库

将 Quectel 提供的相应 RIL 库文件放入 Android 系统的以下路径。作者拷贝到了源码的android_build/device/fsl/imx8m/evk_8mm/lib 目录下&#xff0c;如下图所示&#xff1a; 然后将 apns-conf.xml 拷贝到 android_build/device/fsl/imx8m/evk_8mm/下&#xff0c;如下图所示&a…

设计模式 - 七大软件设计原则

目录 一、设计模式 1.1、软件设计原则 1.1.1、开闭原则 1.2.2、单一职责原则 1.2.3、里氏替换原则 1.2.4、迪米特原则 1.2.5、接口隔离原则 1.2.6、依赖倒转原则 1.2.7、合成/聚合复用原则 一、设计模式 1.1、软件设计原则 1.1.1、开闭原则 开闭原则&#xff1a;对扩…

chromedriver下载与安装方法

下载与安装: 1.查看Chrome浏览器版本 首先&#xff0c;需要检查Chrome浏览器的版本。请按照以下步骤进行&#xff1a; 打开Chrome浏览器。 点击浏览器右上角的菜单图标&#xff08;三个垂直点&#xff09;。 选择“帮助”&#xff08;Help&#xff09;。 在下拉菜单中选择“…

Swagger2的配置

Swagger2的配置&#xff1a; 1.要用到的依赖包&#xff1a; <!-- swagger2 依赖 --><dependency><groupId>io.springfox</groupId><artifactId>springfox-swagger2</artifactId><version>2.7.0</version></dependency>…

网络是什么?(网络零基础入门篇)

1.如何理解局域网和广域网&#xff1f; 2.路由器和交换机是怎么样工作的&#xff1f; 3.三层交换机能不能代替路由器&#xff1f; -- 局域网 广域网 -- 企业网架构&#xff0c;运营商架构&#xff0c;数据中心架构 -- 局域网 通过 交换机连接的 转发 相同的ip地址…

TSINGSEE青犀基于AI视频智能分析的客流统计分析场景方案

随着AI技术的不断发展与人类需求的不断提升&#xff0c;视觉目标的检测识别、智能监控在人们的生活中均有着广泛的应用。其中&#xff0c;智能安防视频监控是计算机视觉的重要应用领域&#xff0c;而AI客流统计则是近年来此领域大家关注热度较高的技术之一。 行业痛点 传统的客…

javaee SpringMVC文件上传 项目结构

引入依赖 <?xml version"1.0" encoding"UTF-8"?><project xmlns"http://maven.apache.org/POM/4.0.0" xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation"http://maven.apache.org/POM/4.0.0…

c++模板库容器list vector map set操作和性能对比

文章目录 listvectormapset性能比较总结 list 列表&#xff08;list&#xff09;是C STL中的一种容器类型&#xff0c;它是一个双向链表&#xff0c;可以在任意位置高效地添加、删除、移动元素。 以下是一些常用的列表操作&#xff1a; 创建列表 #include <list> std…

21.6 CSS 弹性布局

1. 弹性盒子 CSS弹性盒子(Flexbox)是一种布局模型, 用于创建灵活的, 自适应的网页布局. 它的目的是在不同屏幕尺寸和设备上实现一致的布局效果.引入弹性盒布局模型的目的是提供一种更加有效的方式来对一个容器中的子元素进行排列, 对齐和分配空白空间.弹性容器通过设置display…

c++视觉图像线性混合

图像线性混合 使用 cv::addWeighted() 函数对两幅图像进行线性混合。alpha 和 beta 是两幅图像的权重&#xff0c;它们之和应该等于1。gamma 是一个可选的增益&#xff0c;这里设置为0。 你可以通过调整 alpha 的值来改变混合比例。如果 alpha0.5&#xff0c;则两幅图像等权重…

扬尘在线监测是什么?如何实现?

扬尘在线监测技术是一种针对扬尘污染问题的环境监测技术&#xff0c;它通过实时监测和数据分析&#xff0c;为管理者提供准确及时的信息&#xff0c;以便他们可以采取有效的控制措施来减少扬尘污染对空气质量和人们健康的影响。 扬尘在线监测系统通常由传感器、数据采集仪器、…

SpringBoot项目:Cannot find declaration to go to

SpringBoot项目get,set方法总报Cannot find declaration to go to 搜了很多答案&#xff0c;没解决 后来仔细一想&#xff0c;原来是我的idea软件重装了&#xff0c;lombok插件没重新安装导致。 安装步骤&#xff1a; 1、下载地址&#xff1a;https://plugins.jetbrains.com…

12P2532X152 KJ3222X1-BA1 CE4003S2B1 EMERSON DELTAV

12P2532X152 KJ3222X1-BA1 CE4003S2B1 EMERSON DELTAV 除了标准的实时计算、通信和控制&#xff0c;边缘设备和关键网络应用的fog通常执行人工智能(AI)、虚拟现实(VR)和增强现实(AR)解决方案。 目前&#xff0c;制药商和医疗保健机构对它们的需求快速增长&#xff0c;因为它们…

el-table进阶(每条数据分行或合并)

最麻烦的还是css样式&#xff0c;表格样式自己调吧 <!-- ——————————————————————————————————根据数据拓展表格—————————————————————————————————— --> <div style"display: flex"&…

SAP从入门到放弃系列之QM检验方法(Inspection Method)

概述 检验方法描述了如何对检验特征执行检验。 QS21-创建主检验特征时&#xff0c;可以对主检验特征可以分配多种检验方法。关于创建主检验特征详见&#xff1a;SAP从入门到放弃系列之QM主检验特征 当任务清单中包含主检验特征时&#xff0c;将为任务清单中的特征选择特定的…