题目描述
请实现一个函数,用来判断一棵二叉树是不是对称的。如果一棵二叉树和它的镜像一样,那么它是对称的。
例如,二叉树 [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
限制:
注意:本题与主站 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)
}
|