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); } };