题目来源:链接
题目描述:
请实现一个函数,用来判断一棵二叉树是不是对称的。如果一棵二叉树和它的镜像一样,那么它是对称的。
二叉树 [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
代码实现:
def isSymmetric(self, root: TreeNode) -> bool:
def recur(L,R):
if not L and not R:
return True
if not L or not R or L.val != R.val:
return False
return recur(L.left,R.right) and recur(L.right,R.left)
return recur(root.left,root.right) if root else True
解题思路:
先在外层进行启动,
在内层函数中进行判断:
两棵树都为空:对称
两棵树的值不同:不对称
经过前面两轮的筛选,继续递归左子树的左子树,右子树的右子树;左子树的右子树,右子树的左子树