889_根据前序和后序遍历构造二叉树

简介: 889_根据前序和后序遍历构造二叉树

889_根据前序和后序遍历构造二叉树

 

package 二叉树.BT;
import java.util.Arrays;
import java.util.HashMap;
import java.util.Map;
/**
 * https://leetcode-cn.com/problems/construct-binary-tree-from-preorder-and-postorder-traversal/ 
 * @author Huangyujun
 */
//pre = [1,2,4,5,3,6,7], post = [4,5,2,6,7,3,1]
//pre 可以用于划分出两个树,而 post 用于找根
//通过一个 map 更好的划分区间(有了位置)
public class _889_根据前序和后序遍历构造二叉树 {
    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;
        }
    }
    //~前序或后序可以放到map中,这里选择后序)
    // 定义一个 map,键值对,【值, 位置】
        int[] pre;
        int[] post;
        int preIndex = 0;
        Map<Integer, Integer> postOrderMap = new HashMap<>();
        public TreeNode constructFromPrePost(int[] pre, int[] post) {
            this.pre = pre;
            this.post = post;
            int index = 0;
            for (Integer val : post) 
                postOrderMap.put(val, index++);
            return helper(0, post.length - 1);
        }
        private TreeNode helper(int postLeft, int postRight) {
            if (postLeft > postRight || preIndex >= pre.length) 
                return null;
            TreeNode root = new TreeNode(pre[preIndex++]);
            if (preIndex == post.length || postLeft == postRight)
                return root;
            int postIndex = postOrderMap.get(pre[preIndex]);
            root.left = helper(postLeft, postIndex);
            root.right = helper(postIndex + 1, postRight - 1);
            return root;
        }
        /**
         * 大佬代码启发:如何使得第一个根结点判断之后,后序根结点的判断规律趋于一致:都是只要找到: 前序的根(左结点的开始)~
         * 后序的根(第二次) 大佬的代码是: 就是看透前序和后序本身,直接转化成位置{数形结合}
         * 
         * 前序 (根)【*---左子树内容(其实内部也是根左右)----】【----右子树内容----】 
         * 后序:【----左子树内容(其实内部也是左右根)---*】【----右子树内容----】(根)
         * 前序的左子树内部(也是根左右),后序的左子树(也是左右根) 前序当前的根的值A(左子树开始)~走走走~ 后序:根的值A 是相等(则是)  
         * @param pre
         * @param post
         * @return
         */
        // pre = [1,2,4,5,3,6,7], post = [4,5,2,6,7,3,1]
        public TreeNode constructFromPrePost2(int[] pre, int[] post) {
            if (pre == null || pre.length == 0) {
                return null;
            }
            if (pre == null || pre.length == 0) {
                return null;
            }
            // 数组长度为1时,直接返回即可
            if (pre.length == 1) {
                return new TreeNode(pre[0]);
            }
            // 根据前序数组的第一个元素,创建根节点
            TreeNode root = new TreeNode(pre[0]);
            int n = pre.length;
            for (int i = 0; i < post.length; ++i) {
                if (pre[i + 1] == post[i]) {
                    // 根据前序数组第二个元素,确定后序数组左子树范围
                    int left_count = i + 1;
                    // 拆分前序和后序数组,分成四份
                    int[] pre_left = Arrays.copyOfRange(pre, 1, left_count + 1);
                    int[] pre_right = Arrays.copyOfRange(pre, left_count + 1, n);
                    int[] post_left = Arrays.copyOfRange(post, 0, left_count);
                    int[] post_right = Arrays.copyOfRange(post, left_count, n - 1);
                    // 递归执行前序数组左边、后序数组左边
                    root.left = constructFromPrePost(pre_left, post_left);
                    // 递归执行前序数组右边、后序数组右边
                    root.right = constructFromPrePost(pre_right, post_right);
                    break;
                }
            }
            // 返回根节点
            return root;
        }
}
目录
相关文章
|
8月前
|
Java C++ 索引
leetcode-106:从中序与后序遍历序列构造二叉树
leetcode-106:从中序与后序遍历序列构造二叉树
55 0
【LeetCode】105. 从前序与中序遍历序列构造二叉树
题目描述: 给定两个整数数组 preorder 和 inorder ,其中 preorder 是二叉树的先序遍历, inorder 是同一棵树的中序遍历,请构造二叉树并返回其根节点。 示例:
67 0
|
3月前
【LeetCode 37】106.从中序与后序遍历构造二叉树
【LeetCode 37】106.从中序与后序遍历构造二叉树
26 0
|
3月前
|
存储 索引 Python
从中序与后序遍历序列构造二叉树
【10月更文挑战第13天】这段内容介绍了一种基于中序和后序遍历序列构建二叉树的方法。通过识别后序遍历中的根节点,并利用中序遍历划分左右子树,进而递归构建整棵树。文中提供了具体示例及Python代码实现,并分析了该方法的时间与空间复杂度。
114 0
21_从中序与后序遍历序列构造二叉树
21_从中序与后序遍历序列构造二叉树
|
C++ 索引
从前序与中序遍历序列构造二叉树(C++实现)
从前序与中序遍历序列构造二叉树(C++实现)
103 1
|
C++ 索引
从中序与后序遍历序列构造二叉树(C++实现)
从中序与后序遍历序列构造二叉树(C++实现)
88 1
|
8月前
|
C++ 索引 Python
leetcode-105:从前序与中序遍历序列构造二叉树
leetcode-105:从前序与中序遍历序列构造二叉树
50 0
|
存储 算法 C++
【二叉树】利用前序和中序遍历结果生成二叉树并输出其后序和层序遍历结果
【二叉树】利用前序和中序遍历结果生成二叉树并输出其后序和层序遍历结果
165 0
|
存储 算法
二叉树的前序/中序/后序遍历—采用递归与迭代两种方法实现嗷
二叉树的前序/中序/后序遍历—采用递归与迭代两种方法实现嗷