14、树的子结构判断

题目:

输入两颗二叉树A,B, 判断B是否为A的子结构(注意约定空树不是任意一颗树的子结构)

解法:

1、遍历A树节点,寻找节点值和B树根节点值相同的节点。

2、对于步骤1中寻找的节点,判断以该节点为根的子树 是否存在和B一样的子树结构。

3、注意异常输入 和NULL 的判断

代码如下:

    bool HasSubtree(TreeNode* A, TreeNode* B)
    {
        bool res = false;
        //前序遍历节点
        if(A!=NULL && B!=NULL)
        {
            if(A->val == B->val )
                res = DoesTree1HaveTree2(A,B);
            if(res == false)
                res = HasSubtree(A->left,B);
            if(res == false)
                res =HasSubtree(A->right,B);
        }
        return res;
    }
    bool DoesTree1HaveTree2(TreeNode* A, TreeNode* B)
    {
        if(B==NULL)
            return true;
        if(A==NULL )
            return false;
        /*         注意此处 如果把A的判断写在前面 要加上B!=NULL 的判断,该函数只有在判断B不是空树时候才执行
        if(A==NULL & B!=NULL)  因此此处在B==NULL时候 要返回TRUE,因为B已经判断不为空树了,其子树可能为空树,
            return false;        此时的子树为空树情况应该属于A的子结构
        if(B==NULL )
            return true;
        */
        if(A->val != B ->val)
            return false;
        return DoesTree1HaveTree2(A->left,B->left) && DoesTree1HaveTree2(A->right,B->right);
    }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值