news 2026/4/16 19:46:14

面试经典150题[072]:从前序与中序遍历序列构造二叉树(LeetCode 105)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
面试经典150题[072]:从前序与中序遍历序列构造二叉树(LeetCode 105)

从前序与中序遍历序列构造二叉树(LeetCode 105)

题目链接:从前序与中序遍历序列构造二叉树(LeetCode 105)
难度:中等

1. 题目描述

给定两个整数数组preorderinorder,其中preorder是二叉树的先序遍历inorder是同一棵树的中序遍历,请构造二叉树并返回其根节点。

要求:

  • 树中不存在重复元素
  • 数组长度 1 <= n <= 3000
  • -3000 <= preorder[i], inorder[i] <= 3000

示例:

输入: preorder = [3,9,20,15,7], inorder = [9,3,15,20,7] 输出: [3,9,20,null,null,15,7]
输入: preorder = [-1], inorder = [-1] 输出: [-1]

2. 问题分析

2.1 规律

  • 先序遍历:根节点 -> 左子树 -> 右子树
  • 中序遍历:左子树 -> 根节点 -> 右子树
  • 先序的第一个元素总是根节点,在中序中找到根节点的位置,可以分割左/右子树。
  • 递归构建:左子树的前序/中序子序列,右子树的前序/中序子序列。
  • 核心问题:如何高效找到中序中根节点的位置,以分割子树?

2.2 贪心思路

我们使用递归 + 哈希表优化:

  • 使用哈希表存储中序遍历的值到索引的映射,便于 O(1) 查找根节点位置。
  • 递归函数:参数为前序/中序的起始/结束索引。
  • 步骤:
    • 如果子树为空(start > end),返回 None。
    • 取前序第一个元素作为根,pre_idx += 1。
    • 在中序中找到根索引 root_in_idx。
    • 递归构建左子树:中序 [in_start, root_in_idx-1],前序相应部分。
    • 递归构建右子树:中序 [root_in_idx+1, in_end],前序相应部分。
  • 全局 pre_idx 跟踪前序位置,避免切片开销。

3. 代码实现

Python

# Definition for a binary tree node.# class TreeNode:# def __init__(self, val=0, left=None, right=None):# self.val = val# self.left = left# self.right = rightclassSolution:defbuildTree(self,preorder:List[int],inorder:List[int])->Optional[TreeNode]:defhelper(in_start,in_end):nonlocalpre_idxifin_start>in_end:returnNoneroot_val=preorder[pre_idx]root=TreeNode(root_val)pre_idx+=1root_in_idx=idx_map[root_val]root.left=helper(in_start,root_in_idx-1)root.right=helper(root_in_idx+1,in_end)returnroot n=len(preorder)idx_map={val:ifori,valinenumerate(inorder)}pre_idx=0returnhelper(0,n-1)

C++

/** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode *right; * TreeNode() : val(0), left(nullptr), right(nullptr) {} * TreeNode(int x) : val(x), left(nullptr), right(nullptr) {} * TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {} * }; */classSolution{public:TreeNode*buildTree(vector<int>&preorder,vector<int>&inorder){unordered_map<int,int>idx_map;for(inti=0;i<inorder.size();++i){idx_map[inorder[i]]=i;}intpre_idx=0;returnhelper(preorder,inorder,idx_map,pre_idx,0,inorder.size()-1);}private:TreeNode*helper(vector<int>&preorder,vector<int>&inorder,unordered_map<int,int>&idx_map,int&pre_idx,intin_start,intin_end){if(in_start>in_end){returnnullptr;}introot_val=preorder[pre_idx];TreeNode*root=newTreeNode(root_val);++pre_idx;introot_in_idx=idx_map[root_val];root->left=helper(preorder,inorder,idx_map,pre_idx,in_start,root_in_idx-1);root->right=helper(preorder,inorder,idx_map,pre_idx,root_in_idx+1,in_end);returnroot;}};

4. 复杂度分析

  • 时间复杂度:O(n),哈希表构建 O(n),递归遍历每个节点一次
  • 空间复杂度:O(n),哈希表 O(n),递归栈最坏 O(n)

5. 总结

  • 树重建问题+遍历序列→ 递归分割是首选
  • 核心使用哈希表优化索引查找,很通用
    • 类似 BFS 的序列化,但这里是反序列化
    • 可扩展到后序 + 中序的变体

复习

面试经典150题[012]:O(1) 时间插入、删除和获取随机元素(LeetCode 380)
面试经典150题[042]:有效的字母异位词(LeetCode 242)
面试经典150题[057]:链表中是否有环(LeetCode 141)

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 10:45:34

Codex的效率命令与自然语言转换:Anything-LLM辅助编程实测

Codex的效率命令与自然语言转换&#xff1a;Anything-LLM辅助编程实测 在现代软件开发中&#xff0c;我们越来越依赖工具来加速编码过程。GitHub Copilot 的出现让“用自然语言写代码”从设想变为现实——只需一句“创建一个带登录验证的Flask接口”&#xff0c;就能生成结构完…

作者头像 李华
网站建设 2026/4/16 12:15:03

11、Flex扫描器使用指南

Flex扫描器使用指南 1. 构建扫描器的选项 在构建扫描器时,Flex提供了数百个选项。大多数选项可以写成 %option name 的形式放在扫描器的开头,也可以在命令行中写成 --name 。若要关闭某个选项,可在前面加上 no ,例如 %option noyywrap 或 --noyywrap 。在大多数…

作者头像 李华
网站建设 2026/4/15 16:15:15

12、词法分析与语法分析工具使用指南

词法分析与语法分析工具使用指南 1. 词法分析相关函数 在词法分析过程中,有几个重要的函数和宏,它们能帮助我们更灵活地处理输入和控制分析流程。 1.1 yymore() 函数 yymore() 函数可以在规则关联的代码中调用,用于告诉词法分析器将下一个标记追加到当前标记之后。例如…

作者头像 李华
网站建设 2026/4/16 13:55:06

13、Bison解析器的高级特性与使用技巧

Bison解析器的高级特性与使用技巧 1. 错误恢复 当解析器接收到无法解析的输入标记时,会尝试按以下步骤从错误中恢复: 1. 调用 yyerror(“syntax error”) ,通常会将错误报告给用户。 2. 丢弃任何部分解析的规则,直到返回到可以移入特殊错误符号的状态。 3. 从移入一…

作者头像 李华
网站建设 2026/4/16 12:46:19

16、Bison语法冲突解析与解决

Bison语法冲突解析与解决 1. 引言 在使用Bison进行语法解析时,常常会遇到各种冲突,如归约 - 归约冲突和移进 - 归约冲突。了解这些冲突的产生原因和解决方法,对于编写正确、高效的语法解析器至关重要。本文将详细介绍Bison中常见的冲突类型、产生原因以及相应的解决办法。…

作者头像 李华
网站建设 2026/4/16 13:52:08

AutoGLM智能体:重新定义手机AI交互的颠覆性革命

AutoGLM智能体&#xff1a;重新定义手机AI交互的颠覆性革命 【免费下载链接】androidgen-glm-4-9b 项目地址: https://ai.gitcode.com/zai-org/androidgen-glm-4-9b 想象一下&#xff0c;只需对着手机说句话&#xff0c;它就能自动完成朋友圈互动、外卖下单、票务预订等…

作者头像 李华