Featured image of post 剑指 Offer 28. 对称的二叉树

剑指 Offer 28. 对称的二叉树

题目描述

请实现一个函数,用来判断一棵二叉树是不是对称的。如果一棵二叉树和它的镜像一样,那么它是对称的。

例如,二叉树 [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

示例 1:

  • 输入:root = [1,2,2,3,4,4,3]
  • 输出:true

示例 2:

  • 输入:root = [1,2,2,null,3,null,3]
  • 输出:false

限制:

  • 0 <= 节点个数 <= 1000

注意:本题与主站 101 题相同:https://leetcode-cn.com/problems/symmetric-tree/

解法一:递归

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
/**
 * Definition for a binary tree node.
 * type TreeNode struct {
 *     Val int
 *     Left *TreeNode
 *     Right *TreeNode
 * }
 */
func isSymmetric(root *TreeNode) bool {
    var check func(a, b *TreeNode) bool
    check = func(a, b *TreeNode) bool {
        if nil == a && nil == b {
            return true
        }
        if nil == a || nil == b {
            return false
        }
        return a.Val == b.Val && check(a.Left, b.Right) && check(a.Right, b.Left)
    }
    return check(root, root)
}
Licensed under CC BY-NC-SA 4.0
最后更新于 2023/06/16 23:23:12
comments powered by Disqus
Built with Hugo
主题 StackJimmy 设计