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

【leetcode】101. 对称二叉树

对称二叉树

    • 题目
    • 题解
      • 1. 递归
      • 2. 递归
    • 解释
      • 1. 对称
      • 2. 非对称

题目

101. 对称二叉树

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

在这里插入图片描述

题解

1. 递归

# Definition for a binary tree node.
# class TreeNode(object):
#     def __init__(self, val=0, left=None, right=None):
#         self.val = val
#         self.left = left
#         self.right = right
class Solution(object):def isSymmetric(self, root):""":type root: TreeNode:rtype: bool"""if not root:return Truereturn self.compare(root.left, root.right)def compare(self, left, right):#首先排除空节点的情况if left == None and right != None: return Falseelif left != None and right == None: return Falseelif left == None and right == None: return True#排除了空节点,再排除数值不相同的情况elif left.val != right.val: return False#此时就是:左右节点都不为空,且数值相同的情况#此时才做递归,做下一层的判断outside = self.compare(left.left, right.right) #左子树:左、 右子树:右inside = self.compare(left.right, right.left) #左子树:右、 右子树:左isSame = outside and inside #左子树:中、 右子树:中 (逻辑处理)return isSame

来自:代码随想录在这里插入图片描述

2. 递归

# Definition for a binary tree node.
# class TreeNode(object):
#     def __init__(self, val=0, left=None, right=None):
#         self.val = val
#         self.left = left
#         self.right = right
class Solution(object):def isSymmetric(self, root):""":type root: TreeNode:rtype: bool"""if not root:return Truedef dfs(left, right):# 递归的终止条件是两个节点都为空# 或者两个节点中有一个为空# 或者两个节点的值不相等if not (left or right):return Trueif not (left and right):return Falseif left.val!=right.val:return False# 外侧和内侧return dfs(left.left, right.right) and dfs(left.right, right.left)return dfs(root.left, root.right)

解释

1. 对称

假设有一个二叉树如下:

    1/ \2   2/ \ / \
3  4 4  3

步骤 1: 初始调用
isSymmetric 方法首先检查根节点 1 是否为空。根节点不为空,所以调用 dfs(root.left, root.right),即检查 root.left 和 root.right 是否对称。root.left 和 root.right 都是值为 2 的节点。

步骤 2: 递归判断
对于 left 节点和 right 节点(值为 2),检查它们的左右子树是否对称。

比较 left.left 和 right.right(即 3 和 3)。它们值相等,继续递归。

比较 left.right 和 right.left(即 4 和 4)。它们值相等,继续递归。

步骤 3: 递归继续
递归深入到 left.left 和 right.right(3 和 3),以及 left.right 和 right.left(4 和 4)。它们的值相等,因此返回 True。

步骤 4: 完成判断
由于所有的对称条件都满足,最终返回 True,表示该二叉树是对称的。

2. 非对称

考虑以下不对称的二叉树:

    1/ \2   2\   \3   3

步骤 1: 初始调用
isSymmetric 方法检查根节点 1,然后调用 dfs(root.left, root.right),即检查 root.left 和 root.right 是否对称。

root.left 和 root.right 都是值为 2 的节点。

步骤 2: 递归判断
对于 left 和 right(值为 2),继续检查它们的左右子树。

比较 left.left 和 right.right,但是 left.left 是空的,right.right 是值为 3 的节点,返回 False。

步骤 3: 完成判断
由于递归过程中发现不对称,最终返回 False,表示该二叉树不是对称的。

http://www.xdnf.cn/news/1015435.html

相关文章:

  • 编译,多面体库
  • Java SE(13)——工具类
  • 基于深度学习的智能语音合成系统:技术与实践
  • Android中的DX、D8、R8
  • HTML5实现好看的邀请函网页源码
  • 1.13使用 Node.js 操作 SQLite
  • 7. TypeScript接口
  • gazebo仿真中对无人机集成的相机进行标定(VINS-Fusion)
  • 西电新增信息力学与感知学院,26考研正式招生
  • qt配合海康工业相机取图开发
  • UE 新版渲染器输出视频
  • HOT 100 | 73.矩阵置零、54.螺旋矩阵、48.旋转图像
  • 贫血模型与充血模型
  • 从0到1:Dify AI智能体部署与使用全攻略
  • 如何存储和和使用比特币---第1关:比特币的存储
  • 机器学习--分类
  • Kafka入门4.0.0版本(基于Java、SpringBoot操作)
  • [Godot] C#读取CSV表格创建双层字典实现本地化
  • Yarn与NPM缓存存储目录迁移
  • c++ std::function
  • MySQL查询缓存深度剖析
  • 多环境开发配置,Spring boot
  • RK3576 Android14 DMIC调制
  • 前端构建工具Webapck、Vite——>前沿字节开源Rspack详解——2023D2大会
  • 打卡第44天:无人机数据集分类
  • android过渡动画
  • 【Pytorch】(1)Pytorch环境安装-①创建虚拟环境
  • NB-IoT-下行同步、广播信道和信号
  • Volta 管理 Node 版本最佳实践教程
  • 【CATIA的二次开发28】抽象对象Document涉及应用程序连接的属性