题目:相同的树
给定两个二叉树,编写一个函数来检验它们是否相同。
如果两个树在结构上相同,并且节点具有相同的值,则认为它们是相同的。
示例 1:
输入: 1 1
/ \ / \
2 3 2 3
[1,2,3], [1,2,3]
输出: true
示例 2:
输入: 1 1
/ \
2 2
[1,2], [1,null,2]
输出: false
示例 3:
输入: 1 1
/ \ / \
2 1 1 2
[1,2,1], [1,1,2]
输出: false
解题思路:
若两棵树根节点的值不相同,则两棵树不同,返回false结束递归;否则继续递归判断他们的左子树和右子树是否相同。
判断两棵树的左子树/右子树是否相同,依旧可以采用上述中的方法。
随着分解,当出现空树时,若两棵树都为空树,则认为相同;否则认为不同。
代码:
if not p and not q: return True
if p and q and p.val == q.val :
return self.isSameTree(p.left, q.left) and self.isSameTree(p.right, q.right)
return False
结果:
题解参考:LeetCode ID:zui-weng-jiu-xian