leetcode 106. 从中序与后序遍历序列构造二叉树
2023-09-27 14:25:55 时间
根据一棵树的中序遍历与后序遍历构造二叉树。
注意:
你可以假设树中没有重复的元素。
例如,给出
中序遍历 inorder = [9,3,15,20,7]
后序遍历 postorder = [9,15,7,20,3]
返回如下的二叉树:
3
/ \
9 20
/ \
15 7
思路:和前序中序构建二叉树思路一样。
/**
* Definition for a binary tree node.
* public class TreeNode {
* int val;
* TreeNode left;
* TreeNode right;
* TreeNode(int x) { val = x; }
* }
*/
class Solution {
HashMap<Integer,Integer> memo = new HashMap<>();
int[] post;
public TreeNode buildTree(int[] inorder, int[] postorder) {
for(int i = 0;i < inorder.length; i++) memo.put(inorder[i], i);
post = postorder;
TreeNode root = buildTree(0, inorder.length - 1, 0, post.length - 1);
return root;
}
public TreeNode buildTree(int is, int ie, int ps, int pe) {
if(ie < is || pe < ps) return null;
int root = post[pe];
int ri = memo.get(root);
TreeNode node = new TreeNode(root);
node.left = buildTree(is, ri - 1, ps, ps + ri - is - 1);
node.right = buildTree(ri + 1, ie, ps + ri - is, pe - 1);
return node;
}
}
相关文章
- 【LeetCode】寻找峰值 [M](二分)
- 【LeetCode】分割回文串 [M](深度优先遍历)
- 【LeetCode】被围绕的区域 [M](深度优先遍历)
- 【LeetCode】二叉树的锯齿形层序遍历 [M](二叉树遍历)
- 【LeetCode】前序遍历构造二叉搜索树 [M](单调栈)
- LeetCode_图的遍历_中等_797. 所有可能的路径
- LeetCode_二叉树_简单_144.二叉树的前序遍历
- LeetCode_二叉树_中等_106.从中序与后序遍历序列构造二叉树
- LeetCode_二叉树_中等_105.从前序与中序遍历序列构造二叉树
- LeetCode·每日一题·662.二叉树最大宽度·递归·迭代
- LeetCode·107.二叉树的层次遍历||·层次遍历
- LeetCode·每日一题·919.完全二叉树插入器·层次遍历·BFS
- LeetCode-145. 二叉树的后序遍历(java)
- [LeetCode] 271. Encode and Decode Strings 加码解码字符串
- [LeetCode] 37. Sudoku Solver 求解数独
- leetcode 468 验证IP地址
- leetcode 148 排序链表