剑指offer--24.树的子结构

时间限制:1秒 空间限制:32768K 热度指数:407165

题目描述

输入两棵二叉树A,B,判断B是不是A的子结构。(ps:我们约定空树不是任意一个树的子结构)
 
class Solution {
    public:
        bool HasSubtree(TreeNode* pRoot1, TreeNode* pRoot2) {//找到子树的根节点 
            if(pRoot1 == NULL || pRoot2 == NULL) return false;
            bool ans = false;
            if(pRoot1->val == pRoot2->val) ans = isSubtree(pRoot1, pRoot2);
            if(!ans) ans = HasSubtree(pRoot1->left, pRoot2);
            if(!ans) ans = HasSubtree(pRoot1->right,pRoot2);

            return ans;
        }
        bool isSubtree(TreeNode* t1, TreeNode* t2) {//判断左右子树是否一致 
            if(t2 == NULL) return true;
            if(t1 == NULL) return false;
            bool ans = true;
            if(t1->val != t2->val) return false;
            if(ans) ans = isSubtree(t1->left, t2->left);
            if(ans) ans = isSubtree(t1->right,t2->right);

            return ans;
        }
};
原文地址:https://www.cnblogs.com/slothrbk/p/10620156.html