2024.2.21力扣每日一题——从中序和后序遍历序列构建二叉树

2024-04-02 05:12

本文主要是介绍2024.2.21力扣每日一题——从中序和后序遍历序列构建二叉树,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

2024.2.21

      • 题目来源
      • 我的题解
        • 方法一 递归方式
        • 方法二 迭代方式

题目来源

力扣每日一题;题序:106

我的题解

方法一 递归方式
  • 后序特点:[ [左子树的前序遍历结果], [右子树的前序遍历结果],根节点 ]
  • 中序特点:[ [左子树的中序遍历结果], 根节点, [右子树的中序遍历结果] ]
    发现后序遍历的数组最后一个元素代表的即为根节点。知道这个性质后,我们可以利用已知的根节点信息在中序遍历的数组中找到根节点所在的下标,然后根据其将中序遍历的数组分成左右两部分,左边部分即左子树,右边部分为右子树,针对每个部分可以用同样的方法继续递归下去构造。
    时间复杂度:O( n 2 n^2 n2)
    空间复杂度:O(n)
public TreeNode buildTree(int[] inorder, int[] postorder) {return createTree(inorder,postorder,0,inorder.length-1,0,postorder.length-1);
}
public TreeNode createTree(int[] inorder, int[] postorder,int iL,int iR,int pL,int mid){if(iL>iR||pL>mid)return null;int val=postorder[mid];TreeNode root=new TreeNode(val);int index=find(inorder,val,iL,iR);int left=index-iL;int right=iR-index;root.left=createTree(inorder,postorder,iL,index-1,pL,mid-right-1);root.right=createTree(inorder,postorder,index+1,iR,mid-right,mid-1);return root;
}public int find(int[] inorder,int val,int iL,int iR){int index=iL;for(int i=iL;i<=iR;i++){if(inorder[i]==val){index=i;}}return index;
}

在中序遍历中对根节点进行定位时,需要频繁扫描整个中序遍历的结果并找出根节点,时间复杂度较高。可以考虑使用哈希表来帮助快速地定位根节点。在此后构造二叉树的过程中,就只需要 O(1)的时间对根节点进行定位了。

//使用哈希表优化
public TreeNode buildTree(int[] inorder, int[] postorder) {Map<Integer,Integer> map=new HashMap<>();for(int i=0;i<inorder.length;i++){map.put(inorder[i],i);}return createTree(inorder,postorder,0,inorder.length-1,0,postorder.length-1,map);
}
public TreeNode createTree(int[] inorder, int[] postorder,int iL,int iR,int pL,int mid,Map<Integer,Integer> map){if(iL>iR||pL>mid)return null;int val=postorder[mid];TreeNode root=new TreeNode(val);int index=map.get(val);int left=index-iL;int right=iR-index;root.left=createTree(inorder,postorder,iL,index-1,pL,mid-right-1,map);root.right=createTree(inorder,postorder,index+1,iR,mid-right,mid-1,map);return root;
}
方法二 迭代方式

看官方题解,我还没搞明白!!!!

有任何问题,欢迎评论区交流,欢迎评论区提供其它解题思路(代码),也可以点个赞支持一下作者哈😄~

这篇关于2024.2.21力扣每日一题——从中序和后序遍历序列构建二叉树的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

MySQL存储过程之循环遍历查询的结果集详解

《MySQL存储过程之循环遍历查询的结果集详解》:本文主要介绍MySQL存储过程之循环遍历查询的结果集,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言1. 表结构2. 存储过程3. 关于存储过程的SQL补充总结前言近来碰到这样一个问题:在生产上导入的数据发现

基于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. 统计结果可

利用Python实现时间序列动量策略

《利用Python实现时间序列动量策略》时间序列动量策略作为量化交易领域中最为持久且被深入研究的策略类型之一,其核心理念相对简明:对于显示上升趋势的资产建立多头头寸,对于呈现下降趋势的资产建立空头头寸... 目录引言传统策略面临的风险管理挑战波动率调整机制:实现风险标准化策略实施的技术细节波动率调整的战略价

python进行while遍历的常见错误解析

《python进行while遍历的常见错误解析》在Python中选择合适的遍历方式需要综合考虑可读性、性能和具体需求,本文就来和大家讲解一下python中while遍历常见错误以及所有遍历方法的优缺点... 目录一、超出数组范围问题分析错误复现解决方法关键区别二、continue使用问题分析正确写法关键点三

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

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

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

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

PostgreSQL 序列(Sequence) 与 Oracle 序列对比差异分析

《PostgreSQL序列(Sequence)与Oracle序列对比差异分析》PostgreSQL和Oracle都提供了序列(Sequence)功能,但在实现细节和使用方式上存在一些重要差异,... 目录PostgreSQL 序列(Sequence) 与 oracle 序列对比一 基本语法对比1.1 创建序