树的子结构

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

两种方法:递归的和非递归的

第一种:递归的方法:

思路:

对于给定的树A和树B,如果B是A的子树,有三种情况:

第一种:A和B的根相等,这时候判断A和B的左右子树是否分别相等

第二种:B存在于A的左子树中,递归调用本函数

第三种:B存在于A的右子树中,递归调用本函数

这三种情况中,最终需要判定A和B相等,这时候才相当于在A中找到了B,需要单独的一个函数is_SameTree

如果B不是A的子树,有以下情况:

B和A至少有一个为空

所以程序编写如下:

# -*- 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
        if not pRoot1 or not pRoot2:
            return False
        else:
            return self.is_SameTree(pRoot1,pRoot2) or self.HasSubtree(pRoot1.left,pRoot2) or self.HasSubtree(pRoot1.right,pRoot2)
    def is_SameTree(self,pRoot1,pRoot2):
        if not pRoot2:
            return True
        elif not pRoot1 or pRoot1.val!=pRoot2.val:
            return False
        return self.is_SameTree(pRoot1.left,pRoot2.left) and self.is_SameTree(pRoot1.right,pRoot2.right)
    

第二种方法待更新,小伙伴们也可以自己试着实现一下。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

skj1995

你的鼓励是我创作最大的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值