剑指offer:树的子结构
题目描述
输入两棵二叉树A,B,判断B是不是A的子结构。(ps:我们约定空树不是任意一个树的子结构)
10多年的市中网站建设经验,针对设计、前端、开发、售后、文案、推广等六对一服务,响应快,48小时及时工作处理。营销型网站的优势是能够根据用户设备显示端的尺寸不同,自动调整市中建站的显示方式,使网站能够适用不同显示终端,在浏览器中调整网站的宽度,无论在任何一种浏览器上浏览网站,都能展现优雅布局与设计,从而大程度地提升浏览体验。创新互联公司从事“市中网站设计”,“市中网站推广”以来,每个客户项目都认真落实执行。
class TreeNode:
def __init__(self, x):
self.val = x
self.left = None
self.right = None
class Solution:
def HasSubtree(self, pRoot1, pRoot2):
def helper(root1, root2):
# 如果root2已经遍历完了,说明root2的每一个节点都能在pRoot1找到对应的节点
if not root2:
return True
# 如果pRoot1遍历完而pRoot2还没遍历完,说明这root1不是对应的子树根节点
if not root1:
return False
# 如果遍历过程中存在值不相等的节点,说明不是要找的子树
if root1.val != root2.val:
return False
# 如果当前节点的值相同,那么继续遍历剩下的节点
return (helper(root1.left, root2.left)
and helper(root1.right, root2.right))
# 由于题目规定,空树不是子结构,所以特殊处理这种情况
if not pRoot2 or not pRoot1:
return False
res = False
# 首先找到pRoot1中与pRoot2的根节点的值相同的节点root1,
# 然后按照与pRoot2相同的顺序去遍历找到的root1,如果以root1为根节点的子树和pRoot2一样
# 那么说明在pRoot1中找到了跟pRoot2一样的子树。
if pRoot1.val == pRoot2.val:
res = helper(pRoot1, pRoot2)
if not res:
# 递归遍历pRoot1,直到找到一个子树或者遍历完整棵树
res = self.HasSubtree(pRoot1.left, pRoot2) \
or self.HasSubtree(pRoot1.right, pRoot2)
return res
文章名称:剑指offer:树的子结构
网页地址:http://cdiso.cn/article/gcidjo.html