LeetCode-Day62(C++) 572. 另一个树的子树

572. 另一个树的子树

给定两个非空二叉树 st,检验 s 中是否包含和 t 具有相同结构和节点值的子树。s 的一个子树包括 s 的一个节点和这个节点的所有子孙。s 也可以看做它自身的一棵子树。

示例 1:
给定的树 s:

3
/ \

4 5
/
1 2
</pre>

给定的树 t:

4
/
1 2

返回 true,因为 t 与 s 的一个子树拥有相同的结构和节点值。

示例 2:
给定的树 s:

3
/ \

4 5
/
1 2
/
0

给定的树 t:

4
/
1 2

返回 false

这个题的做法就是在 s 的每个子节点上,判断该子节点是否和 t 相等。

判断两个树是否相等的三个条件是与的关系,即:

当前两个树的根节点值相等;
并且,s 的左子树和 t 的左子树相等;
并且,s 的右子树和 t 的右子树相等。
而判断 t 是否为 s 的子树的三个条件是或的关系,即:

当前两棵树相等;
或者,t 是 s 的左子树;
或者,t 是 s 的右子树。

/**
 * 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) {}
 * };
 */
class Solution {
public:
    bool isSubtree(TreeNode* s, TreeNode* t) {
        return dfs(s, t);
    }

    bool check(TreeNode* o, TreeNode* t) {
        if(o == nullptr && t == nullptr) return true;
        else if ((o == nullptr && t != nullptr ) || (o != nullptr && t == nullptr ) || 
        (o-> val != t->val))
        {
            return false;
        }
        return check(o->left, t->left) && check(o->right, t->right);
    }

    bool dfs(TreeNode* o, TreeNode* t) {
        if(o != nullptr) {
            return check(o, t) || dfs(o->left , t) || dfs(o->right, t);
        }
        else return false;
    }
};
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容