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);
    }
};
相关推荐
PAK向日葵4 小时前
【算法导论】PDD 0817笔试题题解
算法·面试
地平线开发者7 小时前
ReID/OSNet 算法模型量化转换实践
算法·自动驾驶
快乐的划水a7 小时前
组合模式及优化
c++·设计模式·组合模式
地平线开发者7 小时前
开发者说|EmbodiedGen:为具身智能打造可交互3D世界生成引擎
算法·自动驾驶
星星火柴9368 小时前
关于“双指针法“的总结
数据结构·c++·笔记·学习·算法
艾莉丝努力练剑9 小时前
【洛谷刷题】用C语言和C++做一些入门题,练习洛谷IDE模式:分支机构(一)
c语言·开发语言·数据结构·c++·学习·算法
闪电麦坤9510 小时前
数据结构:迭代方法(Iteration)实现树的遍历
数据结构·二叉树·
C++、Java和Python的菜鸟10 小时前
第六章 统计初步
算法·机器学习·概率论
Cx330❀10 小时前
【数据结构初阶】--排序(五):计数排序,排序算法复杂度对比和稳定性分析
c语言·数据结构·经验分享·笔记·算法·排序算法
散11210 小时前
01数据结构-Prim算法
数据结构·算法·图论