572. Subtree of Another Tree

https://leetcode.com/problems/subtree-of-another-tree/description/

easy 题也不easy,坑还是多。主要观察两个例子:[1,1] [1] 和 [3,4,5,1,null,null,2] [3,1,2]

第一个例子主要考察当s, t 的val 都一样时,还是有两个情况:1. s 和 t 一模一样,2.t 是s 的子树。我就是把这一点忽略了。

第二个例子是考察检查s,t 是否是一样时的逻辑。

/**
 * 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 sameTree(TreeNode* a, TreeNode* b) {
        if (a == nullptr && b == nullptr) return true;
        if (a == nullptr || b == nullptr) return false;
        if (a->val != b->val) return false;
        return sameTree(a->left, b->left) && sameTree(a->right, b->right);
    }
    bool isSubtree(TreeNode* s, TreeNode* t) {
        if (s == nullptr && t == nullptr) {return true;}
        if (s == nullptr || t == nullptr) {return false;}
        
        if (s->val == t->val) {
            return (sameTree(s->left, t->left) && sameTree(s->right, t->right)) || 
                (isSubtree(s->left, t) || isSubtree(s->right, t));
        }
        
        return isSubtree(s->left, t) || isSubtree(s->right, t);
    }
};
原文地址:https://www.cnblogs.com/agentgamer/p/9779234.html