[leetcode] B树是不是A树的子结构

给定两棵二叉树 tree1tree2,判断 tree2 是否以 tree1 的某个节点为根的子树具有 相同的结构和节点值

注意,空树 不会是以 tree1 的某个节点为根的子树具有 相同的结构和节点值

示例 1:

复制代码
输入:tree1 = [1,7,5], tree2 = [6,1]
输出:false
解释:tree2 与 tree1 的一个子树没有相同的结构和节点值。

示例 2:

复制代码
输入:tree1 = [3,6,7,1,8], tree2 = [6,1]
输出:true
解释:tree2 与 tree1 的一个子树拥有相同的结构和节点值。即 6 - > 1。
复制代码
/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode(int x) : val(x), left(NULL), right(NULL) {}
 * };
 */
class Solution {
public:
    bool isSubStructure(TreeNode* A, TreeNode* B) {
        return (A != nullptr && B != nullptr) && (recur(A, B) || isSubStructure(A->left, B) || isSubStructure(A->right, B));
    }
private:
    bool recur(TreeNode* A, TreeNode* B) {
        if(B == nullptr) return true;
        if(A == nullptr) return false;
        return  A->val != B->val && recur(A->left, B->left) && recur(A->right, B->right);
    }
};
相关推荐
醉城夜风~11 小时前
C++函数参数的默认值及其使用场景
开发语言·c++·算法
tankeven11 小时前
HJ162 ACM中的AC题
c++·算法
无尽的罚坐人生11 小时前
hot 100 56. 合并区间
算法
kishu_iOS&AI11 小时前
机器学习——归一化/标准化(特征工程预处理)
人工智能·算法·机器学习
美式请加冰11 小时前
递归在二叉树搜索中的使用
算法
生信研究猿11 小时前
leetcode 21.合并两个有序链表
python·leetcode·链表
nianniannnn11 小时前
力扣 76. 最小覆盖子串
c++·算法·leetcode
灰色小旋风11 小时前
力扣K个一组翻转链表C++
c++·算法·leetcode
北冥有羽Victoria11 小时前
TGC:深度时序图聚类的动态建模与时空平衡|ICLR 2024 深度解读
人工智能·python·算法·机器学习·支持向量机·聚类
manyikaimen11 小时前
博派智能-运动控制技术-RTCP-五轴联动
c++·图像处理·qt·算法·计算机视觉·机器人·c#