【剑指offer】Q18:树的子结构

类似于字符串的匹配,我们总是找到第一个匹配的字符,在继续比较以后的字符是否全部相同,如果匹配串的第一个字符与模式串的第一个不相同,我们就去查看匹配串的下一个字符是否与模式串的第一个相同,对应到这里,就是我们要遍历root1,找到与root2相同的第一个结点,若root1的根不相同,那么我们查找其左子树是否有第一个相同的,相同的操作再去看右子树是否有相同的第一个,若找到了第一个相同的,与字符串匹配思想一样,字符串匹配中,是比较以后的字符是否全部相同,这里我们比较其左右子树是否 也对应相同,若找到了一个,则结束。

# Q18: subtree
def HasSubTree(root1, root2):
	re = False
	# None is subTree of anyone
	if root2 == None:
		return True
	# root1 is None, but root2 is not None
	if root1 == None:
		return False
	# subtree can start from this node
	if root1.val == root2.val:
		re = DoesTree1HasTree2(root1, root2)
	# subtree may be in root1's left branch
	if re == False and root1.left:
		re = DoesTree1HasTree2(root1.left, root2)
	# subtree may be in root1's right branch
	if re == False and root1.right:
		re = DoesTree1HasTree2(root1.right, root2)
	return re

def DoesTree1HasTree2(root1, root2):
	if root2 == None:
		return True
	if root1 == None:
		return False
	if root1.val != root2.val:
		return False
	return DoesTree1HasTree2(root1.left, root2.left) and \
			DoesTree1HasTree2(root1.right, root2.right)


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值