LeetCode —— 572. 另一棵树的子树

572. 另一棵树的子树

题目:给你两棵二叉树 root 和 subRoot 。检验 root 中是否包含和 subRoot 具有相同结构和节点值的子树。如果存在,返回 true ;否则,返回 false 。

二叉树 tree 的一棵子树包括 tree 的某个节点和这个节点的所有后代节点。tree 也可以看做它自身的一棵子树。

cpp 复制代码
/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
 *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
 * };
 */

 //简单通过中序放入顺序表查找是否有一样部分不行,不论什么遍历顺序都不能保证一样,因为树结构变一下,它们那部分的顺序可能会变一样。所以只能将Tree的所有节点全部当作头节点遍历一遍,通过左右指针来判断。
 //遍历root树的时候都会对root树传的根节点与subroot当作两个树重新遍历一遍,如果相同,则说明sub是子树。
class Solution {
public:
    //判断
    bool isSubtree_(TreeNode* root, TreeNode* subRoot)
    {
        if(root == nullptr && subRoot == nullptr)
            return true;
        if(subRoot == nullptr || root == nullptr)
            return false;
        return (root->val == subRoot->val) && isSubtree_(root->left, subRoot->left) && isSubtree_(root->right, subRoot->right);


    }
    //通过遍历判断
    bool preOrder_judge(TreeNode* root, TreeNode* subRoot)
    {   
        if(root == nullptr)
            return false;
        return isSubtree_(root, subRoot) || preOrder_judge(root->left, subRoot) || preOrder_judge(root->right, subRoot);

    }
    
    bool isSubtree(TreeNode* root, TreeNode* subRoot) {
        //每个节点当作头节点遍历一遍,看是否相等。
        return preOrder_judge(root, subRoot);
    }
};
相关推荐
刚入门的大一新生1 分钟前
C++初阶-list的使用2
开发语言·c++·list
学习噢学个屁17 分钟前
基于51单片机教室红外计数灯光控制—可蓝牙控制
c语言·单片机·嵌入式硬件·51单片机
我也不曾来过135 分钟前
AVL树的实现
算法
jerry6091 小时前
LeetCode 滑动窗口问题 - 核心限制条件总结 (基于灵茶山艾府分类 - 详尽版)
算法·leetcode·分类
yuhao__z1 小时前
代码随想录算法训练营第六十五天| 图论10—卡码网94. 城市间货物运输 I,95. 城市间货物运输 II
java·算法·图论
程序员Jared1 小时前
Qt—模态与非模态对话框
c++·qt
愚润求学1 小时前
【Linux】进程间通信(四):System V标准(共享内存、消息队列、信息量)
linux·运维·服务器·开发语言·c++·笔记
袁气满满~_~1 小时前
LeetCode:贪心算法
算法·leetcode·贪心算法
枫景Maple1 小时前
LeetCode 1340. 跳跃游戏 V(困难)
算法·leetcode
虾球xz1 小时前
游戏引擎学习第304天:构建与遍历图
c++·学习·算法·游戏引擎