【LeetCode面试经典150题】106. 从中序和后序遍历构造二叉树

一、题目

  • 106. 从中序与后序遍历序列构造二叉树 - 力扣(LeetCode)
  • 给定两个整数数组 inorder 和 postorder ,其中 inorder 是二叉树的中序遍历, postorder 是同一棵树的后序遍历,请你构造并返回这颗 二叉树 。

二、思路

  1. 思路和前&中序遍历一致,关键点在于如何划分各种排序的左子树部分和右子树部分并送入下一层递归,见解法一

三、解法

解法一

class Solution {private final HashMap<Integer, Integer> map = new HashMap();public TreeNode buildTree(int[] inorder, int[] postorder) {int inB = 0, inE = inorder.length,postB = 0, postE = postorder.length;for (int i = 0; i < inorder.length; i++) {map.put(inorder[i], i);}return recursion(inorder, inB, inE, postorder, postB, postE);}private TreeNode recursion(int[] inorder, int inB, int inE,int[] postorder, int postB, int postE) {// 递归终止条件if (inB >= inE || postB >= postE) {return null;}// 找到根结点int rootVal = postorder[postE - 1];int rootIndexInIn = map.get(rootVal);// 连接当前结点TreeNode node = new TreeNode(rootVal);// 左子树int leftLen = rootIndexInIn - inB;node.left = recursion(/* 9 (3) 15 20 7 */inorder, inB, rootIndexInIn, /* 9 15 7 20 (3) */postorder, postB, postB + leftLen);// 右子树node.right = recursion(/* 9 (3) 15 20 7 */inorder, rootIndexInIn + 1, inE, /* 9 15 7 20 (3) */postorder, postB + leftLen, postE - 1);return node;}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/31259.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

掌握JavaScript ES6精髓:探索函数和对象的高级扩展与实用技巧

序言 JavaScript&#xff0c;作为前端开发中不可或缺的语言&#xff0c;已经发展到了ECMAScript 2015&#xff08;简称ES6&#xff09;以及后续的版本。ES6带来了诸多语法上的改进和创新&#xff0c;使得代码更加简洁、优雅&#xff0c;同时也提供了更多的编程模式和实用技巧。…

【ONE·基础算法 || 记忆化搜索】

总言 主要内容&#xff1a;编程题举例&#xff0c;熟悉理解记忆化搜索类题型&#xff08;对比递归、动态规划理解运用&#xff09;。             文章目录 总言1、记忆化搜索1.1、基本介绍1.2、细节理解&#xff08;记忆搜索化、递归、动态规划……&#xff09; 2、斐…

idea插件开发之一起来开发个打印方法入参和返回值的插件吧!

写在前面 源码 。 在开发过程中为了调试代码我们就可能就需要知道某个方法入参的值是什么&#xff0c;或者是返回值是什么。此时&#xff0c;我们的解决办法一般都是debug&#xff0c;但是debug的效率说实话其实是不高的&#xff0c;特别是不断的调试&#xff0c;不断的debug。…

[贪心算法]忍者道具

描述 忍者道具有很多种&#xff0c;苦无&#xff0c;飞镖&#xff0c;震爆弹。L君热衷于收集忍者道具&#xff0c;现在他有N个道具&#xff0c;每个道具的重量分别是C1、C2…CN。现在他想把这N个道具装到载重量为W的工具包里&#xff0c;请问他最少需要多少个工具包&#xff1…

KT148A-SOP8语音芯片接收到一线串口指令到播放声音大概多长时间

一、问题简介 请问KT148A-SOP8语音芯片接收到一线串口指令&#xff0c;到播放出来声音&#xff0c;大概需要多长时间 我的需求是做按键提示音&#xff0c;初测了一下感觉有延时&#xff0c;这个要如何处理 详细说明 KT148A从接收到指令&#xff0c;到执行&#xff0c;到播放…

JavaScript基于时间的动画算法

前段时间无聊或有聊地做了几个移动端的HTML5游戏。放在不同的移动端平台上进行测试后有了诡异的发现&#xff0c;有些手机的动画会“快”一点&#xff0c;有些手机的动画会“慢”一点&#xff0c;有些慢得还不是一两点。 通过查找资料发现&#xff0c;基于帧的算法&#xff08…

多模态大模型时代下的文档图像智能分析与处理

0. 前言 随着人工智能技术的不断发展&#xff0c;尤其是深度学习技术的广泛应用&#xff0c;多模态数据处理和大模型训练已成为当下研究的热点之一&#xff0c;这些技术也为文档图像智能处理和分析领域带来了新的发展机遇。 多模态大模型时代下的文档图像智能分析与处理的研究…

Java中的数据结构:选择与优化

Java中的数据结构&#xff1a;选择与优化 大家好&#xff0c;我是免费搭建查券返利机器人省钱赚佣金就用微赚淘客系统3.0的小编&#xff0c;也是冬天不穿秋裤&#xff0c;天冷也要风度的程序猿&#xff01; 在Java编程中&#xff0c;选择合适的数据结构对程序性能和可维护性至…

MySQL UPDATE和DELETE语句的 IN/EXISTS 子查询限制

The MySQL query optimizer has different strategies available to evaluate subqueries: 1、 For a subquery used with an IN, ANY, or EXISTS predicate, the optimizer has these choices: • Semijoin • Materialization • EXISTS strategy 2、 For a subquery used …

Linux:用户账号和权限管理的命令

目录 一、Linux用户的分类和组的分类 1.1、用户账号和组账号 1.2、用户的分类 1.3、组账号 1.4、用户账号文件/etc/passwd 二、用户管理相关命令 2.1、chage命令&#xff1a;用来修改帐号和密码的有效期限&#xff0c;针对目前系统已经存在的用户 2.2、useradd&#xf…

【Numpy】一文向您详细介绍 np.abs()

【Numpy】一文向您详细介绍 np.abs() 下滑即可查看博客内容 &#x1f308; 欢迎莅临我的个人主页 &#x1f448;这里是我静心耕耘深度学习领域、真诚分享知识与智慧的小天地&#xff01;&#x1f387; &#x1f393; 博主简介&#xff1a;985高校的普通本硕&#xff0c;曾…

数据结构-图的基本概念

图的定义 图时由非空的顶点集合和一个描述顶点之间关系的集合组成。可以定义为&#xff1a; ​​​​​​​ ​​​​​​​ ​​​​​​​ G表示一个图&#xff0c;V表示点集&#xff0c;E表示边集。集合E的每一个二元组都包含两个值和&#xff0c;表示…

什么是联盟营销?独立站如何通过联盟营销提高转化率?

什么是联盟营销&#xff1f;独立站如何通过联盟营销提高转化率&#xff1f; 流量紧缺是跨境电商独立站永恒不变的难题&#xff0c;对于独立站卖家来说&#xff0c;广告投放、KOL引流等推广方式都能带来流量&#xff0c;但在广告流量越来越贵的今天&#xff0c;对于跨境电商独立…

Vue快速上手和Vue指令

一、Vue快速上手 1、Vue概念 Vue (读音 /vjuː/&#xff0c;类似于 view) 是一套构建用户界面的渐进式框架 Vue2官网&#xff1a;https://v2.cn.vuejs.org/ 构建用户界面&#xff1a;基于数据渲染出用户可以看到的界面 渐进式&#xff1a; 循序渐进&#xff0c;不一定非得把…

前端 响应式设计之媒体查询

媒体查询&#xff08;Media Queries&#xff09;是用于在网页设计中根据用户设备的特征&#xff08;如屏幕宽度、高度、设备类型等&#xff09;来应用不同的样式表规则的技术。它允许开发者根据用户设备的特性动态调整网页的布局和样式&#xff0c;以提供更好的用户体验。 媒体…

阿里云PAI主机网页访问测试

笔者使用的阿里云平台PAI主机(首次使用免费三个月额度)&#xff0c;由于其默认不设置公网IP&#xff0c;所以在该主机上启动HTTP服务后无法访问测试。 这里使用ssh来作隧道穿透&#xff0c;首先需要配置ssh。 云主机配置ssh 1. 修改root账号密码 在云主机上执行 passwd ro…

安当透明加密(TDE)助力企业建立可信赖的数据环境

​​​​​​​ 透明加密是一种特殊的加密方法&#xff0c;它允许数据在存储或传输过程中自动进行加密和解密&#xff0c;而用户并不需要知道加密过程。这种技术对用户来说是“透明的”&#xff0c;因为它不会改变用户的日常操作习惯&#xff0c;加密和解密过程在后台自动进行…

怎么学习PMP才是最正确的?

每个人的学习方式各不相同&#xff0c;不能一概而论说某种学习方式就是错误的。学习方式并没有绝对的对错之分&#xff0c;只能说是否适合自己&#xff0c;是否能够达到预期的学习效果。并不是别人的学习方式就一定适合自己&#xff0c;也不是不适合自己的学习方式就一定是错误…

【ARMv8/v9 GIC 系列 4 -- GIC 中断分类 SGI | PPI | SPI 及中断检测流程】

文章目录 GIC 中断分类SGI&#xff08;Software Generated Interrupts&#xff09;PPI&#xff08;Per-Processor Interrupts&#xff09;SPI&#xff08;Shared Peripheral Interrupts&#xff09; 中断检测流程物理中断生命周期SPI 中断检测流程PPI 和SGI中断检测流程LPI中断…

分布式数据库的原理

分布式数据库 分布式数据库是将数据存储在多台独立计算机上&#xff0c;这些计算机通过网络连接协同工作的系统。其原理在于将数据分散到多个节点&#xff0c;以提高可用性、可扩展性和容错性。 CAP定理 CAP定理&#xff08;Consistency, Availability, Partition Tolerance…