数据结构与算法中二叉树子结构的详解

发布时间 - 2026-01-11 00:50:20    点击率:

数据结构与算法中二叉树子结构的详解

需求

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

树的描述:

class TreeNode {
  int val = 0;
  TreeNode left = null;
  TreeNode right = null;

  public TreeNode(int val) {
    this.val = val;

  }
}

解决思路

使用了栈将元素入栈,并不断的弹出元素,弹出一个元素的时候,拼接成字符串,并用特殊符号进行区分,该方法主要是按照先序遍历的方式将树节点的数据信息拼接为字符串,这样,两个树的节点拼接而成的串进行判断是不是包含。

不过,有的资料上说可以通过递归的方式进行,但是我感觉以及实践以后发现是错误的。后面会给出代码,读者自行尝试。

public static boolean HasSubtree2(TreeNode root1, TreeNode root2) {

    if (root2 == null)
      return false;
    String str = "";
    Stack<TreeNode> stack = new Stack<TreeNode>();
    stack.push(null);
    stack.push(root1);
    TreeNode node = null;
    while ((node = stack.pop()) != null) {
      str += '_' + node.val + '_';

      if (node.right != null) {
        stack.push(node.right);
      }
      if (node.left != null) {
        stack.push(node.left);
      }
    }

    String str2 = "";
    node = null;
    stack.push(null);
    stack.push(root2);
    while ((node = stack.pop()) != null) {
      str2 += '_' + node.val + '_';

      if (node.right != null) {
        stack.push(node.right);
      }
      if (node.left != null) {
        stack.push(node.left);
      }
    }

    if (str.contains(str2)) {
      return true;
    } else {
      return false;
    }
  }

树的构建

二叉树而言,可以通过数组的方式进行存放,首节点放在数组0号位置处,其左节点在1号位置处,其右节点在2号位置处。由此该index的映射关系为:

index_parent.left => 2* index_parent + 1;
index_parent.right=> 2* index_parent + 2;

构建思路,左节点和右节点分别构建,根节点的左节点就一直追溯其子节点,根节点的右节点一直追溯其子节点,由此,形成的是递归的结构。

代码如下:

注:这里数组中通过-1作为区分,读者可自行扩充。

public static TreeNode getTree(int[] node, int index) {

    if (index >= node.length)
      return null;
    TreeNode n = null;
    if (node[index] != -1) {
      n = new TreeNode(node[index]);
      n.left = getTree(node, index * 2 + 1);
      n.right = getTree(node, index * 2 + 2);
    }
    return n;
  }

完整代码

包括了资料中提供的代码,但是经过测试如下用例中是错误的,但是理论上说tree2应该是tree1的子结构才对。

import java.util.Stack;

public class HasSubtree {

  public static void main(String[] args) {

    TreeNode tree = getTree(new int[] { 8, 8, 7, 9, 2, -1, -1, -1, -1, 4, 7 }, 0);
    TreeNode tree2 = getTree(new int[] { 2, 4, 7 }, 0);
    boolean bool = HasSubtree(tree, tree2);
    System.out.println(bool);

    boolean bool2 = HasSubtree2(tree, tree2);
    System.out.println(bool2);
  }

  public static boolean HasSubtree2(TreeNode root1, TreeNode root2) {

    if (root2 == null)
      return false;
    String str = "";
    Stack<TreeNode> stack = new Stack<TreeNode>();
    stack.push(null);
    stack.push(root1);
    TreeNode node = null;
    while ((node = stack.pop()) != null) {
      str += '_' + node.val + '_';

      if (node.right != null) {
        stack.push(node.right);
      }
      if (node.left != null) {
        stack.push(node.left);
      }
    }

    String str2 = "";
    node = null;
    stack.push(null);
    stack.push(root2);
    while ((node = stack.pop()) != null) {
      str2 += '_' + node.val + '_';

      if (node.right != null) {
        stack.push(node.right);
      }
      if (node.left != null) {
        stack.push(node.left);
      }
    }

    if (str.contains(str2)) {
      return true;
    } else {
      return false;
    }
  }

  public static TreeNode getTree(int[] node, int index) {

    if (index >= node.length)
      return null;
    TreeNode n = null;
    if (node[index] != -1) {
      n = new TreeNode(node[index]);
      n.left = getTree(node, index * 2 + 1);
      n.right = getTree(node, index * 2 + 2);
    }
    return n;
  }

  public static boolean HasSubtree(TreeNode root1, TreeNode root2) {

    boolean result = false;
    if (root1 != null && root2 != null) {

      if (root1.val == root2.val) {
        result = isSubTree(root1, root2);
      }

      if (!result) {
        result = isSubTree(root1.left, root2);
      }

      if (!result) {
        result = isSubTree(root1.right, root2);
      }
    }

    return result;
  }

  private static boolean isSubTree(TreeNode root1, TreeNode root2) {

    if (root1 == null)
      return false;
    if (root2 == null)
      return true;
    if (root1.val != root2.val)
      return false;

    return isSubTree(root1.left, root2.left)
        && isSubTree(root1.right, root2.right);
  }

}

class TreeNode {
  int val = 0;
  TreeNode left = null;
  TreeNode right = null;

  public TreeNode(int val) {
    this.val = val;

  }

}

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!


# 数据结构与算法--二叉树子结构  # 数据结构二叉树  # 使用C语言构建基本的二叉树数据结构  # Java中二叉树数据结构的实现示例  # python数据结构之二叉树的统计与转换实例  # python数据结构之二叉树的遍历实例  # python数据结构之二叉树的建立实例  # python数据结构树和二叉树简介  # 递归  # 可以通过  # 弹出  # 上说  # 二叉树  # 其子  # 的是  # 放在  # 遍历  # 数据结构  # 而成  # 希望能  # 谢谢大家  # 才对  # 主要是  # 组中  # 应该是  # 特殊符号  # 使用了  # 但是我 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 什么是javascript作用域_全局和局部作用域有什么区别?  Win11怎么更改系统语言为中文_Windows11安装语言包并设为显示语言  Laravel Fortify是什么,和Jetstream有什么关系  Laravel如何实现邮箱地址验证功能_Laravel邮件验证流程与配置  重庆市网站制作公司,重庆招聘网站哪个好?  iOS中将个别页面强制横屏其他页面竖屏  Linux系统运维自动化项目教程_Ansible批量管理实战  PHP 500报错的快速解决方法  千问怎样用提示词获取健康建议_千问健康类提示词注意事项【指南】  如何将凡科建站内容保存为本地文件?  Laravel如何使用Sanctum进行API认证?(SPA实战)  免费网站制作appp,免费制作app哪个平台好?  制作电商网页,电商供应链怎么做?  消息称 OpenAI 正研发的神秘硬件设备或为智能笔,富士康代工  如何快速查询网站的真实建站时间?  Laravel怎么配置不同环境的数据库_Laravel本地测试与生产环境动态切换【方法】  Laravel怎么处理异常_Laravel自定义异常处理与错误页面教程  香港服务器网站测试全流程:性能评估、SEO加载与移动适配优化  专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?  Laravel如何实现文件上传和存储?(本地与S3配置)  如何快速查询网址的建站时间与历史轨迹?  HTML5空格在Angular项目里怎么处理_Angular中空格的渲染问题【详解】  Laravel Telescope怎么调试_使用Laravel Telescope进行应用监控与调试  Laravel如何生成PDF或Excel文件_Laravel文档导出工具与使用教程  Laravel怎么写单元测试_PHPUnit在Laravel项目中的基础测试入门  网页设计与网站制作内容,怎样注册网站?  如何在腾讯云服务器上快速搭建个人网站?  手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?  Laravel的HTTP客户端怎么用_Laravel HTTP Client发起API请求教程  Laravel怎么创建自己的包(Package)_Laravel扩展包开发入门到发布  Windows11怎样设置电源计划_Windows11电源计划调整攻略【指南】  ai格式如何转html_将AI设计稿转换为HTML页面流程【页面】  如何在服务器上配置二级域名建站?  网站制作大概要多少钱一个,做一个平台网站大概多少钱?  android nfc常用标签读取总结  Laravel如何发送系统通知?(Notification渠道示例)  如何快速搭建高效香港服务器网站?  Laravel Docker环境搭建教程_Laravel Sail使用指南  如何自定义建站之星网站的导航菜单样式?  香港网站服务器数量如何影响SEO优化效果?  Linux安全能力提升路径_长期防护思维说明【指导】  JavaScript如何实现类型判断_typeof和instanceof有什么区别  Laravel怎么生成URL_Laravel路由命名与URL生成函数详解  Laravel怎么实现模型属性转换Casting_Laravel自动将JSON字段转为数组【技巧】  详解Android图表 MPAndroidChart折线图  Laravel Session怎么存储_Laravel Session驱动配置详解  lovemo网页版地址 lovemo官网手机登录  Laravel怎么实现一对多关联查询_Laravel Eloquent模型关系定义与预加载【实战】  php打包exe后无法访问网络共享_共享权限设置方法【教程】  Laravel如何配置和使用队列处理异步任务_Laravel队列驱动与任务分发实例