题目描述
- 输入两棵二叉树A,B
- 判断B是不是A的子结构。
- 其中空树不是任意一个树的子结构
class TreeNode:
def __init__(self, x):
self.val = x
self.left = None
self.right = None
解题思路
思路1
class Solution:
def HasSubtree(self, pRoot1, pRoot2):
if pRoot1 == None or pRoot2 == None:
return False
return self.is_Subtree(pRoot1,pRoot2) or self.HasSubtree(pRoot1.left,pRoot2) or self.HasSubtree(pRoot1.right,pRoot2)
def is_Subtree(self,pRoot1,pRoot2):
if pRoot2 == None:
return True
elif pRoot1 == None or pRoot1.val != pRoot2.val:
return False
return self.is_Subtree(pRoot1.left,pRoot2.left) and self.is_Subtree(pRoot1.right,pRoot2.right)

本文介绍了一种判断一棵二叉树是否为另一棵二叉树的子结构的方法。通过递归的方式,首先检查两棵树的根节点是否相同,然后分别检查左子树和右子树是否符合子结构条件。
157

被折叠的 条评论
为什么被折叠?



