【LeetCode经典题解】:从前序和中序遍历构建二叉树详解

【LeetCode经典题解】:从前序和中序遍历构建二叉树详解
在这里插入图片描述
🎁个人主页:User_芊芊君子
🎉欢迎大家点赞👍评论📝收藏⭐文章
🔍系列专栏:Java.数据结构
在这里插入图片描述


在这里插入图片描述

【前言】

二叉树构造是算法中递归分治思想的经典应用,而通过前序与中序遍历序列还原二叉树,更是力扣考察二叉树特性的高频题。前序“根左右”、中序“左根右”的遍历特性,是逐层确定根节点、划分左右子树的关键。本文将从递归分治思想出发,拆解该问题的实现逻辑,分析代码设计的核心细节。

文章目录:

一、从前序遍历和中序遍历构造二叉树

链接直达:从前序遍历和中序遍历构造二叉树


在这里插入图片描述

二、思路分析

根据递归分治思想:

前序遍历:根节点—>左子树—>右子树;找到前序序列的第一个元素就是根节点;中序遍历:左子树—>根节点—>右子树;找到根节点在中序序列中的位置,从而确定左子树和右子树;递归处理:重复上面的步骤,依次确定子树的根节点并构建子树,直至子树为空。

三、代码详解

1.代码分析

  • preorder:前序遍历数组;
  • inorder : 中序遍历数组;
  • 成员变量 preIndex : 用于记录前序遍历中当前根节点的索引 (通过通过全局递增依次取前序序列的根节点)
  • findVal 方法:查找根节点在中序序列中的索引rootIndex;
  • 递归方法buildTreeChild
递归终止条件:当 inbegin>inend ,说明当前子树无节点,返回null;构建根节点,取前序数组preIndex位置的元素作为根节点;划分左右子树,通过findVal方法找到根节点在中序序列中的索引rootIndex,inbegin ~ rootIndex-1为左子树,rootIndex+1 ~ inend为右子树

2.代码展示

publicint preIndex;publicTreeNodebuildTree(int[] preorder,int[] inorder){returnbuildTreeChild(preorder, inorder,0,inorder.length-1);}publicintfindVal(int[] inorder,int inbegin,int inend,int key){for(int i = inbegin;i<=inend;i++){if(inorder[i]==key){return i;}}return-1;}publicTreeNodebuildTreeChild(int[] preorder,int[] inorder,int inbegin,int inend){//递归终止条件:当前子树中序区间无节点if(inbegin>inend){returnnull;}//前序序列Index位置作为根节点TreeNode root =newTreeNode(preorder[preIndex]);//在中序序列中找到根节点的索引int rootIndex =findVal(inorder,inbegin,inend,preorder[preIndex]);//preIndex递增,指向下一个子树根节点 preIndex++;//递归左子树,范围:inbegin ~ rootIndex-1 root.left =buildTreeChild(preorder,inorder,inbegin,rootIndex-1);//递归左子树,范围:rootIndex+1 ~ inend root.right =buildTreeChild(preorder,inorder,rootIndex+1,inend);return root;}

【总结】

本文围绕前序+中序构建二叉树问题,解析了递归分治的解题思路:依托前序确定根节点,通过中序划分左右子树区间,再递归构建子树至区间为空。代码中用 prIndex 追踪前序根节点位置,借 findVal定位中序根节点索引完成边界划分,核心是对遍历特性的运用与递归终止条件的设置。此外,还可通过哈希表优化中序查找效率,该思路也为后序+中序构建二叉树等同类问题提供了参考。
在这里插入图片描述

Read more

STM32 Foc开源算法,包括观测器和Foc method STM32F0系列FOC 源代码

STM32 Foc开源算法,包括观测器和Foc method STM32F0系列FOC 源代码

STM32 Foc开源算法,包括观测器和Foc method STM32F0系列FOC 源代码, 有单电阻采样和三电阻采样两种代码。 都是ST很经典算法,代码学习,无感算法观测器是开源代码,Foc method也是开源,不是库。 深夜调完电机准备收工,突然发现实验室角落积灰的STM32F0开发板。这玩意儿当年可是玩FOC的初代神器,今天咱们就扒一扒ST官方藏在GitHub暗处的FOC开源遗产——不带库的纯裸代码,单电阻三电阻玩法都有,观测器源码直接摊开给你看。 电流采样:单电阻的骚操作 单电阻方案最让人头秃的就是电流重构,ST的代码里藏着这样的玄机: void ADC_Handler(void) { if(ADC_GetFlagStatus(ADC_FLAG_EOC)) { // 捕获三个PWM周期内的不同采样点 switch(sampling_phase) { case 0: currA = ADC_GetValue() * voltage_scale; break; case 1: currB = (ADC_

By Ne0inhk
【Git 快速实战】VSCode + Git 环境搭建与全流程指令速通指南

【Git 快速实战】VSCode + Git 环境搭建与全流程指令速通指南

前言:在上一篇【Git 快速入门】团队协作开发核心工作流:从分支管理到代码提交的标准化实践-ZEEKLOG博客中,我们已经打通了“工作区、暂存区、本地仓库、远程仓库”这四个核心空间的任督二脉。如果说上一篇是“心法”,那么这一篇就是实打实的“剑招”。 很多开发者在理论上是个巨人,一到环境搭建就卡壳。这里有一个非常精准的比喻:Git 就像电脑的网卡驱动,而 VSCode 就像浏览器。 就算你装了最新最炫的浏览器(VSCode),如果没装底层驱动(Git),你也连不上代码托管的“网”——即无法进行版本控制。 本文将跳过繁琐的原理,直接通过 VSCode 终端,手把手带你完成从环境复原到模拟企业级开发的完整闭环。 第一阶段:环境复原(驱动安装与配置) 工欲善其事,必先利其器。Leader 交代的任务能否顺利开始,取决于我们的环境是否“干净”且“正确”。 1. 核心驱动安装 前往

By Ne0inhk
Linux系统学习【深入剖析Git的原理和使用(下)】

Linux系统学习【深入剖析Git的原理和使用(下)】

🔥承渊政道:个人主页 ❄️个人专栏: 《C语言基础语法知识》《数据结构与算法》 《C++知识内容》《Linux系统知识》 ✨逆境不吐心中苦,顺境不忘来时路!🎬 博主简介: 引言:在深入剖析Git的原理和使用(上)中,我们已经搭建起Git的基础认知框架—从Git的诞生背景、核心设计理念出发,掌握了初始化仓库、提交版本、查看日志、简单分支创建与切换等基础操作,也初步触及了Git“分布式版本控制”的核心优势.但这些表层操作,仅仅是Git强大功能的冰山一角:当我们面对多人协作中的代码冲突、复杂分支的合并与管理、误操作后的版本回滚难题,或是想弄明白“Git如何高效存储版本数据”“远程仓库与本地仓库的同步逻辑是什么”时,仅靠基础操作往往无从下手,背后的核心原理才是解决这些问题的关键.本篇将聚焦远程仓库的进阶协作(拉取、推送、复刻、协同开发流程).将坚持“原理+实操”结合的思路,真正发挥Git在版本控制、团队协作中的核心价值,为后续的高效开发、规模化协作筑牢基础.接下来,

By Ne0inhk
用 Fiora 搭个专属聊天室?开源社交工具 + cpolar让沟通更自由

用 Fiora 搭个专属聊天室?开源社交工具 + cpolar让沟通更自由

本文介绍了如何利用 Fiora 搭建专属聊天室并通过 cpolar 实现远程访问。Fiora 是开源即时通讯工具,支持注册登录、群组聊天等多种功能,可通过 Docker 在本地部署。为解决局域网使用限制,搭配 cpolar 内网穿透工具,无需公网 IP 和复杂设置即可映射到公网,实现异地访问。文中还提及配置固定二级子域名的方法,方便长期使用,两者结合为私域社群和协作提供了灵活方案。 文章目录 * 前言 * 1.关于Fiora * 2.安装Docker * 3.本地部署Fiora * 4.使用Fiora * 5.cpolar内网穿透工具安装 * 6.创建远程连接公网地址 * 7.固定Uptime Kuma公网地址 * 联系博主 前言 Fiora 是一款开源即时通讯工具,支持账号注册登录、群组聊天、私聊加好友,还能发送文本、表情、图片等多种消息类型,

By Ne0inhk