【C++】每日一题 101 对称二叉树

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

struct TreeNode {int val;TreeNode *left;TreeNode *right;TreeNode(int x) : val(x), left(NULL), right(NULL) {}
};bool isSymmetric(TreeNode* root) {if (root == nullptr) {return true;}return isMirror(root->left, root->right);
}bool isMirror(TreeNode* leftNode, TreeNode* rightNode) {if (leftNode == nullptr && rightNode == nullptr) {return true;}if (leftNode == nullptr || rightNode == nullptr) {return false;}if (leftNode->val != rightNode->val) {return false;}return isMirror(leftNode->left, rightNode->right) && isMirror(leftNode->right, rightNode->left);
}

复杂度分析:

时间复杂度:O(n),其中 n 是二叉树中节点的数量。在最坏情况下,我们需要遍历整个二叉树的节点才能确定是否是轴对称的。
空间复杂度分析:

空间复杂度:O(n),其中 n 是二叉树中节点的数量。在递归过程中,系统需要维护递归调用的栈空间,最坏情况下需要存储整棵树的节点信息。

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

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

相关文章

基于openpose的引体向上的识别计数统计项目(5)CPoseClassify类设计与实现

和CPoseExtract一样, CPoseClassify设计为一个纯虚类,规定了基本的调用接口函数,便于后续扩展使用。该类主要用于判断一帧骨骼关键点数据属于引体向上动作中的状态类型。 // https://www.wikihow.com/Do-a-Chin-Up enum PullupCls {None = -1, // 未知占位Drape = 0, // …

鸿蒙Harmony应用开发—ArkTS声明式开发(基础手势:NavRouter)

导航组件,默认提供点击响应处理,不需要开发者自定义点击事件逻辑。 说明: 该组件从API Version 9开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。 子组件 必须包含两个子组件,其中第二个子组…

【趣味学算法】08 凯撒密码

注: 本系列仅为个人学习笔记,学习内容为《算法小讲堂》(视频传送门),通俗易懂适合编程入门小白,需要具备python语言基础,本人小白,如内容有误感谢您的批评指正 《罗马帝王传》中描述…

分析型数据库的主要使用场景有哪些?

如今数据已经成为了企业和组织的核心资产。如何有效地管理和利用这些数据,成为了决定竞争力的关键。分析型数据库作为数据处理领域的重要工具,为各行各业提供了强大的数据分析和洞察能力。基于分析型数据库(Apache Doris )构建的现…

当模型足够大时,Bias项不会有什么特别的作用

问题来源: 阅读OLMo论文时,发现有如下一段话: 加上前面研究llama和mistral结构时好奇为什么都没有偏置项了 偏置项的作用: 回到第一性原理来分析,为什么要有偏置项的存在呢? 在神经网络中,…

跨境热点!TikTok直播网络要求是什么?

TikTok直播作为一种互动性强、实时性要求高的社交媒体形式,对网络环境有着一系列特定的需求。了解并满足这些需求,对于确保用户体验、提高直播质量至关重要。本文将深入探讨TikTok直播对网络环境的要求以及如何优化网络设置以满足这些要求。 TikTok直播的…

mac启动elasticsearch

1.首先下载软件,然后双击解压,我用的是7.17.3的版本 2.然后执行如下命令 Last login: Thu Mar 14 23:14:44 on ttys001 diannao1xiejiandeMacBook-Air ~ % cd /Users/xiejian/local/software/elasticsearch/elasticsearch-7.17.3 diannao1xiejiandeMac…

[剪藏] - 2024QS世界大学前200名排名榜(101-200)

2024QS世界大学排名(101-200) 排名 校名/国家 综合得分 100 诺丁汉大学 60.4 United Kingdom 102 威斯康星大学麦迪逊分校 60 United States 103 智利天主教大学 59.9 Chile 104 谢菲尔德大学 59.7 United Kingdom 105 乌普萨…

鸿蒙Harmony应用开发—ArkTS声明式开发(基础手势:Menu)

以垂直列表形式显示的菜单。 说明: 该组件从API Version 9开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。 Menu组件需和bindMenu或bindContextMenu方法配合使用,不支持作为普通组件单独使用。 子组件 包含MenuIt…

HTML—CSS盒子模型(Box Model)

基本介绍: CSS处理网页时,HTML的每一个标签可以看作是一个盒子,网页布局将指定的标签放到指定的位置上摆放,相当于摆放盒子。 每一个标签(盒子)所包含的内容:从外到内 ①外边距(margin)—规定盒子与盒子之间的距离&…

LeetCode---388周赛

题目列表 3074. 重新分装苹果 3075. 幸福值最大化的选择方案 3076. 数组中的最短非公共子字符串 3077. K 个不相交子数组的最大能量值 一、重新分装苹果 注意题目中说同一个包裹中的苹果可以分装,那么我们只要关心苹果的总量即可,在根据贪心&#x…

Linux学习-标准IO编程

目录 1.IO输入输出 2.Linux文件类型: 3.普通文件的操作 二进制文件操作 perror() valgrind --toolmemcheck --leak-checkfull filename 1.IO输入输出 操作对象是文件 2.Linux文件类型: b block 块设备文件 按块扫描…

为什么光学器件需要厚度

确定光学厚度的限值 光学元件的功能和性能在很大程度上受到可用光学材料的限制。制造和光学元件设计的最新发展现在拓宽了可以实现的目标。特别是,平面光学器件或超表面可以设计为具有大块光学元件的功能,但其厚度缩小到仅几百纳米。米勒现在提出了一项…

git小白入门

git是什么 Git是一种流行的版本控制系统,被广泛用于软件开发中来跟踪和管理代码的变化。它是由Linus Torvalds在2005年创建的,最初的目的是为了更高效地管理Linux内核的开发。Git使得多人在同一个项目上工作变得更加简单,可以轻松合并不同开…

人工智能入门学习笔记1:什么是人工智能

一、什么是人工智能 人工智能(Artificial Intelligence),是一个以计算机科学(Computer Science)为基础,由计算机、心理学、哲学等多学科交叉融合的交叉学科、新兴学科,研究、开发用于模拟、延伸和扩展人的智能的理论、…

C++ //练习 10.38 列出5个迭代器类别,以及每类迭代器所支持的操作。

C Primer(第5版) 练习 10.38 练习 10.38 列出5个迭代器类别,以及每类迭代器所支持的操作。 环境:Linux Ubuntu(云服务器) 工具:vim 解释 输入迭代器,,!,&…

Centos8安装Docker,使用阿里云源

一、前期准备 1.关闭防火墙,SELINUX systemctl stop firewalld.service systemctl disable firewalld.service setenforce 0 sed -i "s/SELINUXenforcing/SELINUXdisabled/g" /etc/selinux/config查看状态 systemctl status firewalld systemctl status…

蓝桥杯 - 大石头的搬运工 C++ 前缀和 算法 附Java python

题目 思路和解题方法 这段代码的目标是计算给定点集的最小总移动成本,使得所有点都在同一直线上。它通过计算每个点左边和右边的移动成本,然后在所有可能的分割点中选择最小成本。具体步骤如下: 读取输入的点集,每个点表示为 (y, …

深入理解 Java 多线程、Lambda 表达式及线程安全最佳实践

Java 线程 线程使程序能够通过同时执行多个任务而更有效地运行。 线程可用于在不中断主程序的情况下在后台执行复杂的任务。 创建线程 有两种创建线程的方式。 扩展Thread类 可以通过扩展Thread类并覆盖其run()方法来创建线程: public class MyThread extend…

AI学习笔记之六:无监督学习如何帮助人类挖掘数据金矿和防范网络欺诈

在这个大数据时代,企业和组织在过去几十上百年的经营过程中积累了大量的原始数据,其中蕴含着宝贵的商业价值和见解。然而,要从这些海量的、未经标记和处理的数据中发现隐藏的规律和知识,并不是一件容易的事情。这就好比要从一座巨…