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

java 递归实现

java 复制代码
class Solution {
    private HashMap<Integer, Integer> inorderIndexMap;
    private int postorderIndex;

    public TreeNode buildTree(int[] inorder, int[] postorder) {
        inorderIndexMap = new HashMap<>();
        postorderIndex = postorder.length - 1;

        for(int i = 0; i < inorder.length; i++) {
            inorderIndexMap.put(inorder[i], i);
        }

        return Helper(postorder, 0, inorder.length - 1);
    }

    private TreeNode Helper(int[] postorder, int inorderStart, int inorderEnd) {
        if(inorderStart > inorderEnd) return null;
        //首先确定根节点的值
        int rootValue = postorder[postorderIndex--];
        TreeNode root = new TreeNode(rootValue);

        //获取根节点在中序遍历中的索引,用于后面划分左右子树
        int inorderIndex = inorderIndexMap.get(rootValue);

        // 递归构建右子树和左子树
        // 注意:需要先构建右子树,因为后序遍历的顺序是左右根
        root.right = Helper(postorder, inorderIndex + 1, inorderEnd);
        root.left = Helper(postorder, inorderStart, inorderIndex - 1);

        return root;
    }
}
相关推荐
robin_suli11 分钟前
动态规划回文串问题系列一>回文子串
算法·动态规划
观测云1 小时前
日志聚类算法 Drain 的实践与改良
算法·聚类·日志
心软且酷丶1 小时前
leetcode:面试题 17.01. 不用加号的加法(python3解法)
python·算法·leetcode
hjyowl1 小时前
矩阵Matrix(POJ2155)
算法
Dream it possible!1 小时前
LeetCode 热题 100_将有序数组转换为二叉搜索树(42_108_简单_C++)(二叉树;递归)
c++·算法·leetcode·深度优先
MYT_flyflyfly2 小时前
计算机视觉之三维重建-摄像机标定
人工智能·算法·计算机视觉
XiaoLeisj2 小时前
【优选算法 & 分治】深入理解分治算法:分治算法入门小专题详解
算法·leetcode·决策树·深度优先·哈希算法·剪枝·推荐算法
蒲公英的孩子2 小时前
DCU异构程序——带宽测试
c++·分布式·算法·架构
ShuQiHere2 小时前
【ShuQiHere】算法的开枝散叶:从机器学习到深度学习的模型总结
深度学习·算法·机器学习
伊一大数据&人工智能学习日志2 小时前
机器学习经典算法——逻辑回归
人工智能·算法·机器学习·逻辑回归