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

简介: LeetCode(算法)- 105. 从前序与中序遍历序列构造二叉树

题目链接:点击打开链接

题目大意:

解题思路:

相关企业

  • 字节跳动
  • Facebook
  • 亚马逊(Amazon)
  • 谷歌(Google)
  • 微软(Microsoft)
  • 优步(Uber)
  • 彭博(Bloomberg)

AC 代码

  • Java
/*** Definition for a binary tree node.* public class TreeNode {*     int val;*     TreeNode left;*     TreeNode right;*     TreeNode() {}*     TreeNode(int val) { this.val = val; }*     TreeNode(int val, TreeNode left, TreeNode right) {*         this.val = val;*         this.left = left;*         this.right = right;*     }* }*/// 解决方案(1)classSolution {
int[] preorder, inorder;
Map<Integer, Integer>inorderMap=newHashMap<>();
publicTreeNodebuildTree(int[] preorder, int[] inorder) {
this.preorder=preorder;
this.inorder=inorder;
for (inti=0; i<inorder.length; i++) {
inorderMap.put(inorder[i], i);
        }
returnrecur(0, inorder.length-1, 0, preorder.length-1);
    }
TreeNoderecur(intla, intra, intlb, intrb) {
if (la>ra) returnnull;
intpreRoot=preorder[lb];
intmidRoot=inorderMap.get(preRoot);
intleftLen=midRoot-la;
TreeNoderoot=newTreeNode(preRoot);
root.left=recur(la, midRoot-1, lb+1, lb+leftLen);
root.right=recur(midRoot+1, ra, lb+leftLen+1, rb);
returnroot;
    }
}
// 解决方案(2)classSolution {
int[] preorder;
HashMap<Integer, Integer>dic=newHashMap<>();
publicTreeNodebuildTree(int[] preorder, int[] inorder) {
this.preorder=preorder;
for(inti=0; i<inorder.length; i++)
dic.put(inorder[i], i);
returnrecur(0, 0, inorder.length-1);
    }
TreeNoderecur(introot, intleft, intright) {
if(left>right) returnnull;                          // 递归终止TreeNodenode=newTreeNode(preorder[root]);          // 建立根节点inti=dic.get(preorder[root]);                       // 划分根节点、左子树、右子树node.left=recur(root+1, left, i-1);              // 开启左子树递归node.right=recur(root+i-left+1, i+1, right); // 开启右子树递归, root + i - left + 1 => root + (left - (i - 1) + 1) + 1 (根节点索引 + 左子树长度 + 1)returnnode;                                           // 回溯返回根节点    }
}
  • 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) {
this->preorder=preorder;
for(inti=0; i<inorder.size(); i++)
dic[inorder[i]] =i;
returnrecur(0, 0, inorder.size() -1);
    }
private:
vector<int>preorder;
unordered_map<int, int>dic;
TreeNode*recur(introot, intleft, intright) { 
if(left>right) returnnullptr;                        // 递归终止TreeNode*node=newTreeNode(preorder[root]);          // 建立根节点inti=dic[preorder[root]];                            // 划分根节点、左子树、右子树node->left=recur(root+1, left, i-1);              // 开启左子树递归node->right=recur(root+i-left+1, i+1, right); // 开启右子树递归, root + i - left + 1 => root + (left - (i - 1) + 1) + 1 (根节点索引 + 左子树长度 + 1)returnnode;                                            // 回溯返回根节点    }
};
相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
目录
相关文章
|
4月前
|
存储 C++ 索引
最长连续序列(每天刷力扣hot100系列)
本题使用哈希表法求最长连续序列。利用unordered_set存储去重元素,遍历集合时仅当num-1不存在时才作为起点向后扩展,统计连续长度,时间复杂度O(n),空间复杂度O(n)。相比unordered_map更高效,因无需存储值。
|
4月前
|
存储 人工智能 算法
从零掌握贪心算法Java版:LeetCode 10题实战解析(上)
在算法世界里,有一种思想如同生活中的"见好就收"——每次做出当前看来最优的选择,寄希望于通过局部最优达成全局最优。这种思想就是贪心算法,它以其简洁高效的特点,成为解决最优问题的利器。今天我们就来系统学习贪心算法的核心思想,并通过10道LeetCode经典题目实战演练,带你掌握这种"步步为营"的解题思维。
|
8月前
|
Go
【LeetCode 热题100】DP 实战进阶:最长递增子序列、乘积最大子数组、分割等和子集(力扣300 / 152/ 416 )(Go语言版)
本文深入解析三道经典的动态规划问题:**最长递增子序列(LIS)**、**乘积最大子数组** 和 **分割等和子集**。 - **300. LIS** 通过 `dp[i]` 表示以第 `i` 个元素结尾的最长递增子序列长度,支持 O(n²) 动态规划与 O(n log n) 的二分优化。 - **152. 乘积最大子数组** 利用正负数特性,同时维护最大值与最小值的状态转移方程。 - **416. 分割等和子集** 转化为 0-1 背包问题,通过布尔型 DP 实现子集和判断。 总结对比了三题的状态定义与解法技巧,并延伸至相关变种问题,助你掌握动态规划的核心思想与灵活应用!
350 1
|
10月前
|
Go 索引 Perl
【LeetCode 热题100】【二叉树构造题精讲:前序 + 中序建树 & 有序数组构造 BST】(详细解析)(Go语言版)
本文详细解析了二叉树构造的两类经典问题:通过前序与中序遍历重建二叉树(LeetCode 105),以及将有序数组转化为平衡二叉搜索树(BST,LeetCode 108)。文章从核心思路、递归解法到实现细节逐一拆解,强调通过索引控制子树范围以优化性能,并对比两题的不同构造逻辑。最后总结通用构造套路,提供进阶思考方向,帮助彻底掌握二叉树构造类题目。
650 9
|
存储 算法 Java
leetcode算法题-有效的括号(简单)
【11月更文挑战第5天】本文介绍了 LeetCode 上“有效的括号”这道题的解法。题目要求判断一个只包含括号字符的字符串是否有效。有效字符串需满足左括号必须用相同类型的右括号闭合,并且左括号必须以正确的顺序闭合。解题思路是使用栈数据结构,遍历字符串时将左括号压入栈中,遇到右括号时检查栈顶元素是否匹配。最后根据栈是否为空来判断字符串中的括号是否有效。示例代码包括 Python 和 Java 版本。
358 4
|
算法
每日一道算法题(Leetcode 20)
每日一道算法题(Leetcode 20)
211 2
【LeetCode 37】106.从中序与后序遍历构造二叉树
【LeetCode 37】106.从中序与后序遍历构造二叉树
144 0
|
Unix Shell Linux
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
本文提供了几个Linux shell脚本编程问题的解决方案,包括转置文件内容、统计词频、验证有效电话号码和提取文件的第十行,每个问题都给出了至少一种实现方法。
341 6
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
|
Python
【Leetcode刷题Python】剑指 Offer 32 - III. 从上到下打印二叉树 III
本文介绍了两种Python实现方法,用于按照之字形顺序打印二叉树的层次遍历结果,实现了在奇数层正序、偶数层反序打印节点的功能。
198 6
|
搜索推荐 索引 Python
【Leetcode刷题Python】牛客. 数组中未出现的最小正整数
本文介绍了牛客网题目"数组中未出现的最小正整数"的解法,提供了一种满足O(n)时间复杂度和O(1)空间复杂度要求的原地排序算法,并给出了Python实现代码。
435 2