101.对称二叉树 python

server/2025/2/9 5:36:52/

对称二叉树

  • 题目
    • 题目描述
    • 示例 1:
    • 示例 2:
    • 提示:
  • 题解
    • 递归法
      • 步骤
      • 提交结果
    • 迭代法
      • 步骤
      • 提交结果

题目

题目描述

给你一个二叉树的根节点 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

进阶:你可以运用递归和迭代两种方法解决这个问题吗?

题解

要检查一个二叉树是否轴对称,可以通过递归或迭代的方法来解决。这里我们将分别介绍这两种方法。

递归法

递归法的核心思想是比较树的左子树和右子树是否镜像对称。具体来说,对于每一层我们需要比较两个节点,并且这两个节点的子节点也需要满足镜像对称的关系。

步骤

  1. 定义一个辅助函数 isMirror 来判断两棵树是否互为镜像。
  2. isMirror 函数中,首先检查两个节点是否都为空;如果只有一个为空,则不对称;如果都不为空,则需要它们的值相等并且它们的子树也满足镜像关系。
  3. 使用根节点的左右子树作为初始参数调用 isMirror 函数。

以下是 Python 实现:

python">def isSymmetric(root: TreeNode) -> bool:def isMirror(t1: TreeNode, t2: TreeNode) -> bool:if not t1 and not t2: return Trueif not t1 or not t2: return Falsereturn (t1.val == t2.val) and isMirror(t1.right, t2.left) and isMirror(t1.left, t2.right)return isMirror(root, root)

提交结果

在这里插入图片描述

迭代法

迭代法使用队列来进行层次遍历。我们可以将两个需要比较的节点同时入队,然后逐个出队进行比较。

步骤

  1. 如果根节点为空,直接返回 True
  2. 初始化一个队列,将根节点的左右子节点加入队列。
  3. 每次从队列中取出两个节点进行比较,若两者均非空则进一步比较其值是否相等,并将其子节点(注意顺序:一个节点的左子节点与另一个节点的右子节点)依次加入队列。
  4. 若在任意时刻发现不匹配的情况,则返回 False

以下是 Python 实现:

python">def isSymmetric(root: TreeNode) -> bool:if not root:return Truequeue = deque([(root.left, root.right),])while queue:t1, t2 = queue.popleft()# 如果两个节点都是None,继续下一个节点if not t1 and not t2:continue# 如果其中一个节点是None,或者两个节点的值不同,返回Falseif not t1 or not t2 or t1.val != t2.val:return False# 将下一层的节点按照对称的方式加入队列queue.append((t1.left, t2.right))queue.append((t1.right, t2.left))return True

提交结果

在这里插入图片描述

通过上述两种方法,你可以有效地判断一棵二叉树是否轴对称。递归方法更加直观,而迭代方法则避免了潜在的栈溢出问题,尤其适用于深层嵌套的树结构。


http://www.ppmy.cn/server/166135.html

相关文章

微信小程序地图开发总结-规划路线

在现代移动应用中&#xff0c;地图导航功能已成为必不可少的一部分。通过地图 API&#xff0c;我们可以轻松地在应用中集成位置服务和路径规划功能。本篇文章将带大家一起实现一个简单的路径导航功能&#xff0c;使用腾讯地图 API结合微信小程序&#xff0c;实现从当前位置到目…

企业FTP替代升级,实现传输大文件提升100倍!

随着信息技术的飞速发展&#xff0c;网络安全环境也变得越来越复杂。在这种背景下&#xff0c;传统的FTP&#xff08;文件传输协议&#xff09;已经很难满足现代企业对文件传输的需求了。FTP虽然用起来简单&#xff0c;但它的局限性和安全漏洞让它在面对高效、安全的数据交换时…

用 Python 给 Excel 表格截图(20250207)

我搜索了网络上的方案&#xff0c;感觉把 Excel 表格转换为 HTML 再用 platwright 截图是比较顺畅的路径&#xff0c;因为有顺畅的工具链。如果使用的是 Windows 系统则不需要阅读此文&#xff0c;因为 win32com 库更方便。这篇文章中 Excel 转 HTML 的方案&#xff0c;主要弥补…

TaskBuilder项目实战:创建项目

用TaskBuilder开发应用系统的第一步就是创建项目&#xff0c;项目可以是一个简单的功能模块&#xff0c;也可以是很多功能模块的集合&#xff0c;具体怎么划分看各位的实际需要&#xff0c;我们一般会将相互关联比较紧密的一组功能模块放到一个独立的项目内&#xff0c;以便打包…

基于javaweb的SpringBoot小区智慧园区管理系统(源码+文档+部署讲解)

&#x1f3ac; 秋野酱&#xff1a;《个人主页》 &#x1f525; 个人专栏:《Java专栏》《Python专栏》 ⛺️心若有所向往,何惧道阻且长 文章目录 运行环境开发工具适用功能说明 运行环境 Java≥8、MySQL≥5.7、Node.js≥14 开发工具 后端&#xff1a;eclipse/idea/myeclipse…

DeepFM:融合因子分解机与深度学习的CTR预测模型

引言 点击率&#xff08;Click-Through Rate, CTR&#xff09;预测是推荐系统和计算广告领域的核心任务。传统方法通常依赖人工特征工程或单一模型架构&#xff0c;难以同时捕捉低阶与高阶特征交互。为了克服这些限制&#xff0c;研究者们不断探索新的模型架构&#xff0c;以更…

基于ArcGIS的SWAT模型+CENTURY模型模拟流域生态系统水-碳-氮耦合过程研究

流域是一个相对独立的自然地理单元&#xff0c;它是以水系为纽带&#xff0c;将系统内各自然地理要素连结成一个不可分割的整体。碳和氮是陆地生态系统中最重要的两种化学元素&#xff0c;而在流域系统内&#xff0c;水-碳-氮是相互联动、不可分割的耦合体。随着流域内人类活动…

ansible自动化运维

ansible自动化运维 1、实现远程连接主机 2、批量配置&#xff0c;批量操作&#xff0c;ansible可以对主机进行组划分&#xff0c;也可以把名下所有的主机进行划分&#xff0c;进行批量的操作。 3、远程自动化运维&#xff08;脚本-------------playbook剧本&#xff09; an…