[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);
    }
};
相关推荐
美好的事情能不能发生在我身上13 小时前
Leetcode热题100中的:矩阵专题
算法·leetcode·矩阵
Tisfy13 小时前
LeetCode 3296.移山所需的最少秒数:优先队列
算法·leetcode·题解·优先队列·模拟
㓗冽13 小时前
龟兔赛跑预测-进阶题6
算法
云泽80813 小时前
蓝桥杯算法精讲:贪心算法的简单应用与题解
算法·贪心算法·蓝桥杯
程序员夏末13 小时前
【LeetCode | 第四篇】算法笔记
笔记·算法·leetcode
DeepModel13 小时前
【概率分布】多项分布详解
算法·概率论
_日拱一卒13 小时前
LeetCode(力扣):只出现一次的数字
java·数据结构·算法
bulingg13 小时前
LR逻辑回归详解
算法·机器学习·逻辑回归
2301_8008951013 小时前
日期问题--备战蓝桥杯版
职场和发展·蓝桥杯
七七肆十九13 小时前
PTA 习题4-7 最大公约数和最小公倍数
数据结构·算法