【算法】【递归篇】【树】第6节:leetcode 101. 对称二叉树

本期任务:介绍leetcode中树的几个经典问题的递归解法

【算法】【递归篇】【树】第1节:leetcode 100. 相同的树

【算法】【递归篇】【树】第2节:leetcode 105. 从前序与中序遍历序列构造二叉树

【算法】【递归篇】【树】第3节:leetcode 210. 课程表 II

【算法】【递归篇】【树】第4节:leetcode 236. 二叉树的最近公共祖先

【算法】【递归篇】【树】第5节:leetcode 572. 另一个树的子树

【算法】【递归篇】【树】第6节:leetcode 101. 对称二叉树

【算法】【递归篇】【树】第7节:leetcode 98. 验证二叉搜索树

【算法】【递归篇】【树】第8节:leetcode 102. 二叉树的层序遍历


问题来源

  • 101. 对称二叉树

101. 对称二叉树
给定一个二叉树,检查它是否是镜像对称的。

 

例如,二叉树 [1,2,2,3,4,4,3] 是对称的。

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

但是下面这个 [1,2,2,null,3,null,3] 则不是镜像对称的:

    1
   / \
  2   2
   \   \
   3    3

大佬解析

  • 画解算法:101. 对称二叉树

递归结束条件:

  • 都为空指针则返回 true
  • 只有一个为空则返回 false

递归过程:

  • 判断两个指针当前节点值是否相等
  • 判断 A 的右子树与 B 的左子树是否对称
  • 判断 A 的左子树与 B 的右子树是否对称

代码

class TreeNode:
    def __init__(self, x):
        self.val = x
        self.left = None
        self.right = None

class Solution:
    def isSymmetric(self, root: TreeNode) -> bool:
        def isSame(l, r):     
            if not l and not r:
                return True  
            if not l or not r:
                return False     
            return l.val == r.val and isSame(l.left, r.left) and isSame(l.right, r.right)
        return isSame(root, root)

你可能感兴趣的:(leetcode,二叉树,递归法)