剑指 Offer 26. 树的子结构

一、题目

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

B是A的子结构, 即 A中有出现和B相同的结构和节点值。

二、思路

先序遍历树 A 中的每个节点 nA;(对应函数 isSubStructure(A, B))

判断树 A中 以 nA为根节点的子树 是否包含树 B。(对应函数 recur(A, B))

三、代码

class Solution:
    def isSubStructure(self, A: TreeNode, B: TreeNode) -> bool:
        def recur(A, B):
            if not B: return True
            if not A or A.val != B.val: return False
            return recur(A.left, B.left) and recur(A.right, B.right)

        return bool(A and B) and (recur(A, B) or self.isSubStructure(A.left, B) or self.isSubStructure(A.right, B))

四、分析

复杂度分析:
时间复杂度 O(MN) : 其中 M,N 分别为树 A  和 树 B  的节点数量;先序遍历树 A 占用 O(M) ,每次调用 recur(A, B) 判断占用 O(N)  。
空间复杂度 O(M) : 当树 A 和树 B 都退化为链表时,递归调用深度最大。当 M≤N 时,遍历树 A 与递归判断的总递归深度为 M ;当 M>N 时,最差情况为遍历至树 A 叶子节点,此时总递归深度为 M 。

posted @ 2022-12-08 08:24  ImreW  阅读(34)  评论(0)    收藏  举报