题目描述:
输入两棵二叉树A,B,判断B是不是A的子结构。(ps:我们约定空树不是任意一个树的子结构)
思路:
递归。
代码:
/**
* 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 isSubtree(TreeNode* s, TreeNode* t) {
if (s == NULL || t == NULL) return false;
return same(s, t) || isSubtree(s->left, t) || isSubtree(s->right, t);
}
bool same(TreeNode* s, TreeNode* t) {
if (t == NULL && s == NULL) return true;
if (s == NULL || t == NULL) return false;
if (s->val != t->val) return false;
return same(s->left, t->left) && same(s->right, t->right);
}
};
好困。平时感觉不到,可以在学校里两耳不闻窗外事,只认真看书是真的幸福。
从明天开始改为早七点起床。