《剑指offer》之树的子结构(python实现)

 

问题描述:

        输入两棵二叉树A,B,判断B是不是A的子结构。(ps:我们约定空树不是任意一个树的子结构)

思路分析:
(思路整体上参考了牛客网评论区的答案)
对于两棵二叉树来说,要判断B是不是A的子结构----首先第一步在树A中查找与B根节点的值一样的节点;
第二步就是判断树A中以R为根节点的子树是不是和树B具有相同的结构;
如果节点R的值和树的根节点不相同,则以R为根节点的子树和树B肯定不具有相同的节点,也就是B不是A的子树;
如果它们值是相同的,则递归的继续判断各自的左右节点的值是不是相同,终止条件是我们达到了树A或者树B的叶节点。

 

python实现代码如下:

# -*- 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 != None and pRoot2 != None:
            if pRoot1.val == pRoot2.val:
                result = self.DoesP1HaveP2(pRoot1,pRoot2)
            if not result:
                result = self.DoesP1HaveP2(pRoot1.left,pRoot2)
            if not result:
                result = self.DoesP1HaveP2(pRoot1.right,pRoot2)
            return result
    def DoesP1HaveP2(self, ptr1, ptr2):
        if ptr2 == None:
            return True
        if ptr1 == None:
            return False
        if ptr1.val != ptr2.val:
            return False
        return self.DoesP1HaveP2(ptr1.left, ptr2.left) and self.DoesP1HaveP2(ptr1.right, ptr2.right)

另一种方式代码如下:

(看到评论区一位华科平凡的大神将其转换为字符串来判断是不是含有相同的子结构,nb啊膜拜各路大神,默默学习)

class Solution:
    def HasSubtree(self, pRoot1, pRoot2):
         
        def convert(p):
            if p:
                return str(p.val) +  convert(p.left) + convert(p.right)
            else:
                return ""
        return convert(pRoot2) in convert(pRoot1) if pRoot2 else False

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值