当前位置: 首页 > article >正文

101.对称二叉树 python

对称二叉树

  • 题目
    • 题目描述
    • 示例 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 实现:

def isSymmetric(root: TreeNode) -> bool:
    def isMirror(t1: TreeNode, t2: TreeNode) -> bool:
        if not t1 and not t2: return True
        if not t1 or not t2: return False
        return (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 实现:

def isSymmetric(root: TreeNode) -> bool:
    if not root:
        return True
    
    queue = deque([(root.left, root.right),])
    
    while queue:
        t1, t2 = queue.popleft()
        
        # 如果两个节点都是None,继续下一个节点
        if not t1 and not t2:
            continue
        
        # 如果其中一个节点是None,或者两个节点的值不同,返回False
        if 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.kler.cn/a/536849.html

相关文章:

  • 什么是Spring
  • SystemUI中NavigationBar分析
  • 什么是自动化测试?自动化测试的作用
  • 星闪开发入门级教程之安装编译器与小项目烧录
  • 第6章《VTK与Qt集成》
  • 自己实现的一个缓存数据库(搞着玩) .net Core/6/8/9
  • 【现代深度学习技术】深度学习计算 | 读写文件
  • UdpServer
  • springboot基于微信小程序的仓储管理系统
  • Python——Unicode 编码 或 解码 工具(通用版)
  • PHP:动态网站开发的灵活之选
  • .net的一些知识点
  • 无法使用ip连接服务器的mysql
  • Verilog代码实例
  • 摄像头模块烟火检测
  • 【提示工程】:如何有效与大语言模型互动
  • 蓝桥杯 Java 之输入输出
  • matlab simulink 汽车四分之一模型主动被动悬架-LQR
  • 【Apache Paimon】-- 15 -- 利用 paimon-flink-action 同步 postgresql 表数据
  • MySQL数据库(五)索引1
  • 通过制作docker镜像的方式在阿里云部署前端后台服务
  • cuda手搓CNN识别手写数字
  • 【SpringBoot如何解决跨域问题?】
  • 【STM32系列】利用MATLAB配合ARM-DSP库设计IIR数字滤波器(保姆级教程)
  • YOLOv11-ultralytics-8.3.67部分代码阅读笔记-dist.py
  • 离线统信系统的python第三方库批量安装流程