码迷,mamicode.com
首页 > 其他好文 > 详细

剑指offer——树的子结构

时间:2018-08-23 15:35:04      阅读:135      评论:0      收藏:0      [点我收藏+]

标签:off   self   desc   pre   bottom   btree   offer   none   tom   

题目描述

输入两棵二叉树A,B,判断B是不是A的子结构。(ps:我们约定空树不是任意一个树的子结构)
 
# -*- coding:utf-8 -*-
# class TreeNode:
#     def __init__(self, x):
#         self.val = x
#         self.left = None
#         self.right = None
def IsSubtree(root1,root2):
    if root2==None:
        return True
    elif root1==None:
        return False
    elif root1.val==root2.val:
        return IsSubtree(root1.left,root2.left)and IsSubtree(root1.right,root2.right)
    else:
        return False
        
class Solution:
    def HasSubtree(self, pRoot1, pRoot2):
        # write code here
        if pRoot2 == None or pRoot1==None:
            return False
        return IsSubtree(pRoot1,pRoot2) or self.HasSubtree(pRoot1.left,pRoot2) or self.HasSubtree(pRoot1.right,pRoot2)
        

 

剑指offer——树的子结构

标签:off   self   desc   pre   bottom   btree   offer   none   tom   

原文地址:https://www.cnblogs.com/hit-joseph/p/9523504.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!