美文网首页二叉树
【剑指 offer】树的子结构。

【剑指 offer】树的子结构。

作者: 邓泽军_3679 | 来源:发表于2019-04-12 21:49 被阅读0次

    1、题目描述

    输入两棵二叉树A,B,判断B是不是A的子结构。

    我们规定空树不是任何树的子结构。

    样例
    树A
    8
    / \
    8 7
    / \
    9 2
       / \
      4 7
    树B:

    8
    / \
    9 2
    返回 true ,因为B是A的子结构。

    2、问题描述:

    3、问题关键:

    • 两层递归,递归每个结点为起点的树。递归每个树的对应的点。

    4、C++代码:

    /**
     * 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 hasSubtree(TreeNode* p1, TreeNode* p2) {
            if (!p1 || !p2) return false;
            if (help(p1, p2)) return true;
            return hasSubtree(p1->left, p2) || hasSubtree(p1->right, p2);//这个地方的递归是对所有的子树递归。
        }
        bool help(TreeNode *p1, TreeNode *p2) {
            if (!p2) return true;
            if (!p1 || p1->val != p2->val) return false;
            return help(p1->left, p2->left) && help(p1->right, p2->right);//这个地方的递归是对当前树的递归。
        }
    };
    

    相关文章

      网友评论

        本文标题:【剑指 offer】树的子结构。

        本文链接:https://www.haomeiwen.com/subject/kcahwqtx.html