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

相关文章

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

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

使用Python构建一个Hexo博客发布工具

《使用Python构建一个Hexo博客发布工具》虽然Hexo的命令行工具非常强大,但对于日常的博客撰写和发布过程,我总觉得缺少一个直观的图形界面来简化操作,下面我们就来看看如何使用Python构建一个... 目录引言Hexo博客系统简介设计需求技术选择代码实现主框架界面设计核心功能实现1. 发布文章2. 加

C语言函数递归实际应用举例详解

《C语言函数递归实际应用举例详解》程序调用自身的编程技巧称为递归,递归做为一种算法在程序设计语言中广泛应用,:本文主要介绍C语言函数递归实际应用举例的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录前言一、递归的概念与思想二、递归的限制条件 三、递归的实际应用举例(一)求 n 的阶乘(二)顺序打印

一文详解如何从零构建Spring Boot Starter并实现整合

《一文详解如何从零构建SpringBootStarter并实现整合》SpringBoot是一个开源的Java基础框架,用于创建独立、生产级的基于Spring框架的应用程序,:本文主要介绍如何从... 目录一、Spring Boot Starter的核心价值二、Starter项目创建全流程2.1 项目初始化(

使用Java实现通用树形结构构建工具类

《使用Java实现通用树形结构构建工具类》这篇文章主要为大家详细介绍了如何使用Java实现通用树形结构构建工具类,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录完整代码一、设计思想与核心功能二、核心实现原理1. 数据结构准备阶段2. 循环依赖检测算法3. 树形结构构建4. 搜索子

使用Python和python-pptx构建Markdown到PowerPoint转换器

《使用Python和python-pptx构建Markdown到PowerPoint转换器》在这篇博客中,我们将深入分析一个使用Python开发的应用程序,该程序可以将Markdown文件转换为Pow... 目录引言应用概述代码结构与分析1. 类定义与初始化2. 事件处理3. Markdown 处理4. 转

Jackson库进行JSON 序列化时遇到了无限递归(Infinite Recursion)的问题及解决方案

《Jackson库进行JSON序列化时遇到了无限递归(InfiniteRecursion)的问题及解决方案》使用Jackson库进行JSON序列化时遇到了无限递归(InfiniteRecursi... 目录解决方案‌1. 使用 @jsonIgnore 忽略一个方向的引用2. 使用 @JsonManagedR

Java使用Mail构建邮件功能的完整指南

《Java使用Mail构建邮件功能的完整指南》JavaMailAPI是一个功能强大的工具,它可以帮助开发者轻松实现邮件的发送与接收功能,本文将介绍如何使用JavaMail发送和接收邮件,希望对大家有所... 目录1、简述2、主要特点3、发送样例3.1 发送纯文本邮件3.2 发送 html 邮件3.3 发送带

Python结合Flask框架构建一个简易的远程控制系统

《Python结合Flask框架构建一个简易的远程控制系统》这篇文章主要为大家详细介绍了如何使用Python与Flask框架构建一个简易的远程控制系统,能够远程执行操作命令(如关机、重启、锁屏等),还... 目录1.概述2.功能使用系统命令执行实时屏幕监控3. BUG修复过程1. Authorization

Rust中的BoxT之堆上的数据与递归类型详解

《Rust中的BoxT之堆上的数据与递归类型详解》本文介绍了Rust中的BoxT类型,包括其在堆与栈之间的内存分配,性能优势,以及如何利用BoxT来实现递归类型和处理大小未知类型,通过BoxT,Rus... 目录1. Box<T> 的基础知识1.1 堆与栈的分工1.2 性能优势2.1 递归类型的问题2.2