day47(12.28)——leetcode面试经典150

106. 从中序与后序遍历序列构造二叉树

106. 从中序与后序遍历序列构造二叉树

我感觉我的数据结构都要忘光光了

题目:

题解:

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;
 *     }
 * }
 */
class Solution {
    public Map<Integer,Integer> map = new HashMap<>();
    public int[] postorder;
    public TreeNode buildTree(int[] inorder, int[] postorder) {
        for(int i=0;i<inorder.length;i++) {
            map.put(inorder[i], i);
        }
        this.postorder = postorder;
        return recur(0,inorder.length-1,0,postorder.length-1);
    }

    public TreeNode recur(int left, int right, int l,int r) {
        if(left > right || l > r) {
            return null;
        }
        int root = postorder[r];
        int i = map.get(root);

        TreeNode node = new TreeNode(root);
        node.left = recur(left, i-1, l, l+i-1-left);
        node.right = recur(i+1, right, l+i-left, r-1);
        return node;
    }
}
相关推荐
晴殇i25 分钟前
揭秘JavaScript中那些“不冒泡”的DOM事件
前端·javascript·面试
绝无仅有1 小时前
Redis过期删除与内存淘汰策略详解
后端·面试·架构
绝无仅有1 小时前
Redis大Key问题排查与解决方案全解析
后端·面试·架构
AAA梅狸猫2 小时前
Looper.loop() 循环机制
面试
AAA梅狸猫2 小时前
Handler基本概念
面试
Gorway2 小时前
解析残差网络 (ResNet)
算法
Wect2 小时前
浏览器缓存机制
前端·面试·浏览器
拖拉斯旋风3 小时前
LeetCode 经典算法题解析:优先队列与广度优先搜索的巧妙应用
算法
Wect3 小时前
LeetCode 207. 课程表:两种解法(BFS+DFS)详细解析
前端·算法·typescript
掘金安东尼3 小时前
Fun with TypeScript Generics:玩转 TS 泛型
前端·javascript·面试