105. Construct Binary Tree from Preorder and Inorder Traversal 递归构建树

2024-08-23 20:48

本文主要是介绍105. Construct Binary Tree from Preorder and Inorder Traversal 递归构建树,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

已知树的先序和中序遍历结果,构建原树

先序可以确定根节点,在中序遍历中找到与根节点对应的数值的索引,其左侧为左子树 ,右侧为右子树。递归构建;

需要几个参数,先序遍历的起始索引(只确定根节点),中序遍历的起始索引,中序遍历的截止索引(起始到终止索引为子树的范围)




public class Solution {public TreeNode buildTree(int[] preorder, int[] inorder) {return helper(0,0,preorder.length-1,preorder,inorder);}public TreeNode helper(int prestart,int instart,int inend,int[] preorder,int[]inorder){if(prestart>preorder.length-1||instart>inend) return null;TreeNode root=new TreeNode(preorder[prestart]);int index=0;for(int i=instart;i<=inend;i++){if(root.val==inorder[i])index=i;}root.left=helper(prestart+1,instart,index-1,preorder,inorder);root.right=helper(prestart+index-instart+1,index+1,inend,preorder,inorder);  //prestart+(index-instart)+1  index-instart根据中序确定左子树的节点值,
这样既可确定右子树的位置return root;}
}

中序、后续构建树:

public class Solution {public TreeNode buildTree(int[] inorder, int[] postorder) {return conTree(inorder,postorder,0,0,inorder.length-1,postorder.length-1);}public TreeNode conTree(int[] inorder,int[] postorder,int instart,int poststart,int inend,int postend){if (instart > inend) {return null;}int index=0;TreeNode root=new TreeNode(postorder[postend]);for(int i=instart;i<=inend;i++){if(inorder[i]==root.val)index=i;}root.right=conTree(inorder,postorder,index+1,poststart+index-instart,inend,postend-1);root.left=conTree(inorder,postorder,instart,poststart,index-1,poststart+index-instart-1);return root;}}

这篇关于105. Construct Binary Tree from Preorder and Inorder Traversal 递归构建树的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1100457

相关文章

基于Python实现一个Windows Tree命令工具

《基于Python实现一个WindowsTree命令工具》今天想要在Windows平台的CMD命令终端窗口中使用像Linux下的tree命令,打印一下目录结构层级树,然而还真有tree命令,但是发现... 目录引言实现代码使用说明可用选项示例用法功能特点添加到环境变量方法一:创建批处理文件并添加到PATH1

基于Python构建一个高效词汇表

《基于Python构建一个高效词汇表》在自然语言处理(NLP)领域,构建高效的词汇表是文本预处理的关键步骤,本文将解析一个使用Python实现的n-gram词频统计工具,感兴趣的可以了解下... 目录一、项目背景与目标1.1 技术需求1.2 核心技术栈二、核心代码解析2.1 数据处理函数2.2 数据处理流程

Python FastMCP构建MCP服务端与客户端的详细步骤

《PythonFastMCP构建MCP服务端与客户端的详细步骤》MCP(Multi-ClientProtocol)是一种用于构建可扩展服务的通信协议框架,本文将使用FastMCP搭建一个支持St... 目录简介环境准备服务端实现(server.py)客户端实现(client.py)运行效果扩展方向常见问题结

详解如何使用Python构建从数据到文档的自动化工作流

《详解如何使用Python构建从数据到文档的自动化工作流》这篇文章将通过真实工作场景拆解,为大家展示如何用Python构建自动化工作流,让工具代替人力完成这些数字苦力活,感兴趣的小伙伴可以跟随小编一起... 目录一、Excel处理:从数据搬运工到智能分析师二、PDF处理:文档工厂的智能生产线三、邮件自动化:

详解如何使用Python从零开始构建文本统计模型

《详解如何使用Python从零开始构建文本统计模型》在自然语言处理领域,词汇表构建是文本预处理的关键环节,本文通过Python代码实践,演示如何从原始文本中提取多尺度特征,并通过动态调整机制构建更精确... 目录一、项目背景与核心思想二、核心代码解析1. 数据加载与预处理2. 多尺度字符统计3. 统计结果可

一文教你Java如何快速构建项目骨架

《一文教你Java如何快速构建项目骨架》在Java项目开发过程中,构建项目骨架是一项繁琐但又基础重要的工作,Java领域有许多代码生成工具可以帮助我们快速完成这一任务,下面就跟随小编一起来了解下... 目录一、代码生成工具概述常用 Java 代码生成工具简介代码生成工具的优势二、使用 MyBATis Gen

Python使用Reflex构建现代Web应用的完全指南

《Python使用Reflex构建现代Web应用的完全指南》这篇文章为大家深入介绍了Reflex框架的设计理念,技术特性,项目结构,核心API,实际开发流程以及与其他框架的对比和部署建议,感兴趣的小伙... 目录什么是 ReFlex?为什么选择 Reflex?安装与环境配置构建你的第一个应用核心概念解析组件

Python+wxPython构建图像编辑器

《Python+wxPython构建图像编辑器》图像编辑应用是学习GUI编程和图像处理的绝佳项目,本教程中,我们将使用wxPython,一个跨平台的PythonGUI工具包,构建一个简单的... 目录引言环境设置创建主窗口加载和显示图像实现绘制工具矩形绘制箭头绘制文字绘制临时绘制处理缩放和旋转缩放旋转保存编

mysql递归查询语法WITH RECURSIVE的使用

《mysql递归查询语法WITHRECURSIVE的使用》本文主要介绍了mysql递归查询语法WITHRECURSIVE的使用,WITHRECURSIVE用于执行递归查询,特别适合处理层级结构或递归... 目录基本语法结构:关键部分解析:递归查询的工作流程:示例:员工与经理的层级关系解释:示例:树形结构的数

Java中的StringBuilder之如何高效构建字符串

《Java中的StringBuilder之如何高效构建字符串》本文将深入浅出地介绍StringBuilder的使用方法、性能优势以及相关字符串处理技术,结合代码示例帮助读者更好地理解和应用,希望对大家... 目录关键点什么是 StringBuilder?为什么需要 StringBuilder?如何使用 St