劍指offer 二叉樹的子結構

題目描述: 
輸入兩棵二叉樹A,B,判斷B是不是A的子結構。(ps:我們約定空樹不是任意一個樹的子結構)

 

思路: 
本題可以分爲兩步,第一步:找到A中與B的根結點值相等的結點R,第二步:判斷以R爲根結點的子樹是否包含B一樣的結構。本題思路不難,但是需要格外注意對指針空值的判斷。

# -*- coding:utf-8 -*-
# class TreeNode:
#     def __init__(self, x):
#         self.val = x
#         self.left = None
#         self.right = None
class Solution:
    def HasSubtree(self, pRoot1, pRoot2):
        # write code here
        result = False
        if pRoot1 and pRoot2:
            if pRoot1.val == pRoot2.val:
                result = self.isSubtree(pRoot1, pRoot2)
            # 判斷左子樹中是否包含B樹結構
            if not result:
                result = self.HasSubtree(pRoot1.left, pRoot2)
            # 判斷右子樹中是否包含B樹結構
            if not result:
                result = self.HasSubtree(pRoot1.right, pRoot2)

        return result

    def isSubtree(self, root1, root2):
        # 如果B樹爲空,那麼可以算B是A的子結構
        if not root2:
            return True
        # 如果A樹空,而B樹不空,那麼B不是A的子結構
        if not root1:
            return False
        if root1.val != root2.val:
            return False
        # 根節點值相同,在判斷左右子樹是否都相同
        return self.isSubtree(root1.left, root2.left) and self.isSubtree(root1.right, root2.right)

 

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