当前位置:首页 > 牛客 > 牛客3732题解:递归分治判断二叉树子树关系

牛客3732题解:递归分治判断二叉树子树关系

4个月前 (08-07)

牛客3732题解:递归分治判断二叉树子树关系 牛客题解 二叉树 递归 分治算法 树结构 C++ 第1张

一、题目解读

牛客3732题要求判断二叉树A是否包含二叉B作为子树。即是否存在A的某子树与B结构完全相同(节点值、左右子树关系均匹配)。问题核心在于高效搜索A的所有子树并与B进行比对,需避免重复遍历。

二、解题思路

核心思想为:

1. 递归分治:将大问题拆解为小问题,分别判断A的根节点是否等于B的根节点,若相等则递归检查左右子树;

2. 子树匹配:设计isSame函数判断两树是否完全相同,通过递归遍历左右子树并比对节点值;

3. 三种可能性:若A的根节点匹配B,或A的左/右子树包含B,则返回true。

三、解题步骤

1. 主函数HasSubtree:

    输入校验:若A或B为空,直接返回false;

    递归判断三种情况:

        以A为根节点的子树是否与B相同(调用isSame);

        A的左子树是否包含B;

        A的右子树是否包含B。

2. 辅助函数isSame:

    若B为空,说明B已匹配完成,返回true;

    若A为空但B不空,匹配失败;

    若节点值不相等,失败;

    递归检查A的左右子树是否与B的左右子树匹配。

四、代码与注释

class Solution {
private:
    bool isSame(TreeNode* A, TreeNode* B) {
        // B为空表示B树已经匹配完成
        if (B == nullptr) return true;
        // A为空但B不为空,匹配失败
        if (A == nullptr) return false;
        // 当前节点值不相等,匹配失败
        if (A->val!= B->val) return false;
        // 递归检查左右子树
        return isSame(A->left, B->left) && isSame(A->right, B->right);
    }
public:
    bool HasSubtree(TreeNode* pRoot1, TreeNode* pRoot2) {
        if (pRoot1 == nullptr || pRoot2 == nullptr) return false;
        // 三种情况满足一种即可:
        // 1. 以pRoot1为根节点的子树包含pRoot2
        // 2. pRoot2在pRoot1的左子树中
        // 3. pRoot2在右子树中
        return isSame(pRoot1, pRoot2) || HasSubtree(pRoot1->left, pRoot2) ||
               HasSubtree(pRoot1->right, pRoot2);
    }
};

五、总结

本解法通过递归分治将子树匹配问题分解为局部节点比对,时间复杂度O(nm)(n、m为两树节点数),空间复杂度O(n+m)(递归)。关键在于设计清晰的递归逻辑与边界条件,适用于需要判断树包含关系的场景,体现了递归算法的优雅与高效。


原创内容 转载请注明出处

分享给朋友:

相关文章

70.爬楼梯|三步破解动态规划核心奥秘

70.爬楼梯|三步破解动态规划核心奥秘

题意新解:站在楼梯底仰望n级台阶,每步可选1或2阶,最终的路径组合犹如斐波那契数列般展开。比如到达第3阶的路径可由第1阶跨两步,或第2阶跨一步构成,这种递推规律揭示了两两相邻状态间的紧密关联。思路解析...

【深度优先搜索实战】力扣547题:省份数量问题的图论解法

【深度优先搜索实战】力扣547题:省份数量问题的图论解法

题目解读‌我们面对的是一个典型的图论问题:给定一个城市的连接矩阵,需要计算其中相互连通的城市群(省份)数量。这个问题可以抽象为无向图中的连通分量计算,每个城市代表图中的一个节点,城市之间的连接关系代表...

标题:洛谷B3617题解析:八进制转十六进制算法实现与优化(附AC100代码)

标题:洛谷B3617题解析:八进制转十六进制算法实现与优化(附AC100代码)

一、题目解读洛谷B3617题要求将输入的八进制字符串转换为十六进制表示。题目需处理大数场景,且对输入合法性有明确限制(长度不超过1000,仅包含0-7字符)。由于八进制与十六进制无法直接转换,需借助十...

牛客14496题解:括号最大深度问题(栈思想与代码优化)

牛客14496题解:括号最大深度问题(栈思想与代码优化)

一、题目解读牛客14496题要求计算给定括号字符串中的最大深度。例如,对于字符串 "(()())",最大深度为2。题目考察对括号嵌套结构的理解,以及如何通过编程找到最深嵌套层次。二...

洛谷1220题解:动态规划与区间DP优化解法(附代码注释)

洛谷1220题解:动态规划与区间DP优化解法(附代码注释)

一、题目解读洛谷1220题要求计算在n个位置放置灯的情况下,通过关闭连续区间灯并移动至区间端点,使得总耗电量最小。需考虑灯的功率与位置差异,设计高效的算法求解最优策略。二、解题思路1. 动态规划 +...

洛谷1656题解:基于Tarjan算法求解割边问题(附代码与详细步骤)

洛谷1656题解:基于Tarjan算法求解割边问题(附代码与详细步骤)

一、题目解读洛谷1656题要求在无向图中找出所有割边(即删除后导致图不连通的边)。题目核心在于判断图的连通性,并识别哪些边是“桥”。需理解图论中的连通分量概念,以及如何通过算法高效定位割边。二、解题思...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。