ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

剑指 Offer 26. 树的子结构

2022-01-06 12:01:59  阅读:141  来源: 互联网

标签:26 val 递归 Offer 结点 子结构 null check


 第一次接触二叉树的递归类型的题目。 一般对于这种题目,我们需要做的是:1. 写一个递归方法。 2. 在主方法里调用这个递归方法

 一. 写一个递归方法

  对于递归方法,我们可以分为两部分 —— 1. 基本情况 2. 特殊情况基本情况实际上就是递归的退出条件,而特殊情况就是进行递归。 对于这个题目,我们会写一个check(TreeNode A,TreeNode B)的递归方法,它的主要作用就是判断 B结点是否为A结点的子结构

  那么我们先分析一下基本情况:1. 如果B结点为 null,那么它最起码不会干扰最终结果,因此返回 true,这种情况已经包含了 B==null&&A==null的情况。 2. 如果A结点为null而B结点不为null,那么肯定返回 false。3. 如果A结点的 val 与 B结点的 val 不相等,那么返回 false。

  我们再分析一下特殊情况:也就是还无法判断B是否为A结点的子结构,说明 A.val == B.val,那么我们接下来要做的就是,判断B的左右子节点是不是A的左右子节点 的子结构。这时候我们就要进行递归调用:调用 check(A.left,B.left) 和 check(A.right,B.right)。并返回两者的结果。

    public boolean check(TreeNode A, TreeNode B){
        //基本情况
        if(B==null){
            return true;//B的结构为空,不影响结果,返回true
        }
        if(A==null||A.val!=B.val){
            return false; //A是空或值不同,不是子树
        }
        //特殊情况,递归,查看左子树和右子树是否构成子结构
        return check(A.left,B.left)&&check(A.right,B.right);
    }

 

二. 在主方法里调用递归方法

  首先我们在主方法里要把特殊情况先写出来,也即 A==null || B==null 时,返回false。

  然后我们就需要考虑:我们应该怎么样调用递归方法。首先我们可以调用 check(A,B),来查看B是否为A的子结构。但是问题是,B有可能是A的左子树的子结构,或者A的右子树的子结构,因此我们不能单单从 check(A,B)的结果就判断B是否为A的子结构。我们还需要判断 B是否为A的左子树/右子树的子结构,因此我们还需要递归调用主方法。

    public boolean isSubStructure(TreeNode A, TreeNode B) {
        if(A==null||B==null){
           return false;
        }
        //递归调用主方法,查看是否为左右子树的子结构(只要满足一种情况即可)
        return check(A,B)||isSubStructure(A.left,B)||isSubStructure(A.right,B);
    }

  

 

标签:26,val,递归,Offer,结点,子结构,null,check
来源: https://www.cnblogs.com/Acc222222/p/15770495.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有