剑指offer面试题28. 对称的二叉树(递归)

题目描述

请实现一个函数,用来判断一棵二叉树是不是对称的。如果一棵二叉树和它的镜像一样,那么它是对称的。
在这里插入图片描述

思路

详见链接

代码

class Solution:
	def isSymmetric(self, root:TreeNode)->bool:
		def recur(L, R):
			if not L and nor 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

复杂度

时间复杂度 O(N) : 其中 N为二叉树的节点数量,每次执行 recur() 可以判断一对节点是否对称,因此最多调用 N/2次 recur() 方法。
空间复杂度 O(N): 最差情况下(见下图),二叉树退化为链表,系统使用 O(N)大小的栈空间。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章