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

给定两棵二叉树 tree1 和 tree2,判断 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);
    }
};

相关推荐

  1. C语言每日一题—判断BA

    2024-04-30 22:04:05       37 阅读
  2. 为什么索引底层结构B+

    2024-04-30 22:04:05       39 阅读
  3. 判断二叉搜索【c++】

    2024-04-30 22:04:05       36 阅读
  4. 什么

    2024-04-30 22:04:05       61 阅读
  5. 什么决策

    2024-04-30 22:04:05       32 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-30 22:04:05       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-30 22:04:05       106 阅读
  3. 在Django里面运行非项目文件

    2024-04-30 22:04:05       87 阅读
  4. Python语言-面向对象

    2024-04-30 22:04:05       96 阅读

热门阅读

  1. 程序包 org.junit 不存在解决方案

    2024-04-30 22:04:05       31 阅读
  2. 安全架构概述

    2024-04-30 22:04:05       26 阅读
  3. 【工程记录】ChatGLM3-6B微调实践的更新说明

    2024-04-30 22:04:05       34 阅读
  4. 前端项目文件夹命名,用横线好,还行下划线好

    2024-04-30 22:04:05       27 阅读
  5. Python 学习笔记

    2024-04-30 22:04:05       32 阅读
  6. 区块链详解

    2024-04-30 22:04:05       25 阅读
  7. docker-compose docker的批量管理工具

    2024-04-30 22:04:05       32 阅读
  8. js关于数字的方法

    2024-04-30 22:04:05       29 阅读
  9. FPGA之zynq_DDR(1)

    2024-04-30 22:04:05       34 阅读
  10. C语言入门练习(1)

    2024-04-30 22:04:05       31 阅读