您的位置:首页 > 其它

LeetCode Same Tree

2016-02-02 19:37 337 查看

LeetCode解题之Same Tree

原题

判断两棵二叉树是否相等。两棵二叉树仅在它们的形状相同且每个节点的值相等时才判为相等。

注意点:



例子:

输入:

[code]      2           2
p =  / \    q =  / \
    1   3       1   3


输出: True

解题思路

树相关的问题一般用递归的方法最好理解。如果两棵树对应的节点都为空,则相等;如果值相等,那么就分别判断它们的左右子树是否相等,否则认为两棵树不相等。

AC源码

[code]# Definition for a binary tree node.
class TreeNode(object):
    def __init__(self, x):
        self.val = x
        self.left = None
        self.right = None

class Solution(object):
    def isSameTree(self, p, q):
        """
        :type p: TreeNode
        :type q: TreeNode
        :rtype: bool
        """
        if not q and not p:
            return True
        elif not p or not q:
            return False
        elif p.val != q.val:
            return False
        else:
            return self.isSameTree(p.left, q.left) and self.isSameTree(p.right, q.right)

if __name__ == "__main__":
    None


欢迎查看我的Github (https://github.com/gavinfish/LeetCode-Python) 来获得相关源码。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: