leetcode hot100 easy 101. 对称二叉树 递归 层序遍历 bfs


判断一棵树是否对称,本质上是看它的左子树和右子树是否互为"镜像"。

递归解法(双指针)

比较左节点和右节点的值是否相等

递归"三部曲"的应用:

1. 出口:

  • 两个都为空 → \rightarrow → 对称(True)。
  • 一个为空一个不为空 → \rightarrow → 不对称(False)。
  • 值不相等 → \rightarrow → 不对称(False)。

2. 操作:

  • 比较 left.val 是否等于 right.val。

3. 递归调用:

  • 比较"左手的左手"和"右手的右手"(外侧)。比较"左手的右手"和"右手的左手"(内侧)。

时间复杂度 : O ( N ) O(N) O(N)。每个节点最多被访问一次。
空间复杂度 :递归: O ( H ) O(H) O(H),取决于树的高度。

python 复制代码
# Definition for a binary tree node.
# class TreeNode:
#     def __init__(self, val=0, left=None, right=None):
#         self.val = val
#         self.left = left
#         self.right = right
class Solution:
    def isSymmetric(self, root: Optional[TreeNode]) -> bool:


        if not root:
            return True

        # 新建一个递归函数,用于比较左右节点(原函数参数只有root, 不方便)
        def check(left, right):

            # 3种出口
            if not left and not right:   #全空
                return True

            if not left or not right:    #单空
                return False

            # 全不空,则比较左右节点的值,和左右节点的外子树, 内子树
            return (left.val == right.val) and check(left.left, right.right) and check(left.right, right.left)

        return check(root.left, root.right)

原函数:任务是"检查这棵树是不是对称的"。

辅助函数:任务是"检查这两个节点是不是镜像的"。


层序遍历 bfs (迭代)

层序遍历(BFS)本质上就是迭代

BFS 的标准实现就是利用循环(while)和队列(Queue)进行的迭代

  1. 把 root.left 和 root.right 放入队列。
  2. 每次弹出两个节点进行比较。
  3. 如果比较通过,按照镜像顺序放入它们的后代:
    放入 left.left 和 right.right(外侧一对)。
    放入 left.right 和 right.left(内侧一对)。

时间复杂度 : O ( N ) O(N) O(N)。每个节点最多被访问一次。
空间复杂度 : O ( N ) O(N) O(N),最坏情况下队列会存储大量节点。

python 复制代码
# Definition for a binary tree node.
# class TreeNode:
#     def __init__(self, val=0, left=None, right=None):
#         self.val = val
#         self.left = left
#         self.right = right


from collections import deque

class Solution:
    def isSymmetric(self, root: Optional[TreeNode]) -> bool:

        if not root: 
            return True

        # 初始双端队列,放入左右节点
        queue = deque([root.left, root.right])

        while queue:

            # 弹出左右节点
            l = queue.popleft()
            r = queue.popleft()

            # 3种失败
            if not l and not r: 
                continue
            if not l or not r:
                return False
            if l.val != r.val:   # 节点的值不等
                return False

            # 两个节点都存在,且值相等
            # 未来要比较的:成对存入镜像位置的节点
            #外
            queue.append(l.left)
            queue.append(r.right)
            #内
            queue.append(l.right)
            queue.append(r.left)

        return True

            

        

迭代法(BFS)的精髓:"队列就是你的待办清单(To-do List)"。

相关推荐
夜天炫安全18 小时前
数据结构中所需的C语言基础
c语言·数据结构·算法
2301_7890156219 小时前
DS进阶:AVL树
开发语言·数据结构·c++·算法
qyzm1 天前
天梯赛练习(3月13日)
开发语言·数据结构·python·算法·贪心算法
逆境不可逃1 天前
LeetCode 热题 100 之 64. 最小路径和 5. 最长回文子串 1143. 最长公共子序列 72. 编辑距离
算法·leetcode·动态规划
CoderCodingNo1 天前
【GESP】C++五级练习题 luogu-P1182 数列分段 Section II
开发语言·c++·算法
放下华子我只抽RuiKe51 天前
机器学习全景指南-直觉篇——基于距离的 K-近邻 (KNN) 算法
人工智能·gpt·算法·机器学习·语言模型·chatgpt·ai编程
kisshuan123961 天前
[特殊字符]【深度学习】DA3METRIC-LARGE单目深度估计算法详解
人工智能·深度学习·算法
sali-tec1 天前
C# 基于OpenCv的视觉工作流-章33-Blod分析
图像处理·人工智能·opencv·算法·计算机视觉
Eward-an1 天前
LeetCode 239. 滑动窗口最大值(详细技术解析)
python·算法·leetcode
一叶落4381 天前
LeetCode 50. Pow(x, n)(快速幂详解 | C语言实现)
c语言·算法·leetcode