剑指Offer打卡26.树的子结构

Posted 余光、

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了剑指Offer打卡26.树的子结构相关的知识,希望对你有一定的参考价值。

剑指 Offer 26. 树的子结构

JavaScript剑指Offer题解

🚀包含数组、对象、链表、堆栈、树等经典题型
☕️每天一道,轻松不累
💬详细的题目解析,收藏方便阅读
🙏在线star地址

在线阅读地址

在线阅读地址

题目描述

输入两棵二叉树A和B,判断B是不是A的子结构。(约定空树不是任意一个树的子结构)

B是A的子结构, 即 A中有出现和B相同的结构和节点值。

例如:

给定的树 A:

     3
    / \\
   4   5
  / \\
 1   2
给定的树 B:

   4 
  /
 1

返回 true,因为 B 与 A 的一个子树拥有相同的结构和节点值。

示例 1:

输入:A = [1,2,3], B = [3,1]
输出:false

示例 2:

输入:A = [3,4,5,1,2], B = [4,1]
输出:true

题解:递归

思路:

判断B是否为A的子结构:

  1. 判断A和B是否一致(结构相同),如果是,那么B是A的子结构。
  2. 如果不是,判断B是否是A的左孩子或者右孩子的子结构,如果是,那么B是A的子结构,如果不是,那么B不是A的子结构(递归)

判断A和B是否一致:

  1. 判断当前B是null? 那么B一直到叶节点了都匹配上了,返回true
  2. 判断当前A是null? 那么A是nullB不是null,此时肯定不匹配 返回false
  3. 判断当前A的值和B的值,如果不相等,肯定不匹配,返回false
  4. 如果前面通过,则下一步判断A的孩子和B的孩子是否一致。(递归)
/**
 * @param {TreeNode} A
 * @param {TreeNode} B
 * @return {boolean}
 */
var isSubStructure = function(A, B) {
    if(!A || !B)return false
    // A,B完全相等
    // B是左子树的某一段的子树
    // B是右子树的某一段的子树
    return isSameTree(A,B) || isSubStructure(A.left,B) || isSubStructure(A.right,B);
};

var isSameTree = function(A,B){
    if(B==null) return true;
    if(A==null) return false;
    if(A.val!=B.val) return false;
    return isSameTree(A.left,B.left) && isSameTree(A.right,B.right)
}

写在最后

本篇是剑指Offer的第18题,俗话说好的合理的数据结构+算法才是写好代码的关键,不妨跟我一起来吧~

热门开源项目

以上是关于剑指Offer打卡26.树的子结构的主要内容,如果未能解决你的问题,请参考以下文章

乱序版 ● 剑指offer每日算法题打卡题解—— 搜索与回溯算法 (题号26,27, 28)

剑指offer--26树的子结构

剑指 Offer 26. 树的子结构

LeetCode(剑指 Offer)- 26. 树的子结构

剑指 Offer 26. 树的子结构 / 剑指 Offer 27. 二叉树的镜像 / 剑指 Offer 28. 对称的二叉树 / 剑指 Offer 29. 顺时针打印矩阵

无取巧解法,易于理解!剑指 Offer 26. 树的子结构