数据结构和算法

二叉树-7.重构二叉树

2023-12-17  本文已影响0人  我阿郑

输入某二叉树的前序遍历中序遍历的结果,请构建该二叉树并返回其根节点。(假设输入的前序遍历和中序遍历的结果中都不含重复的数字。)

Input: preorder = [3,9,20,15,7], inorder = [9,3,15,20,7]
Output: [3,9,20,null,null,15,7]

Input: preorder = [-1], inorder = [-1]
Output: [-1]
image.png
前序遍历 : 4,2,1,3,6,8
中序遍历: 1,2,3,4,8,6
 4
/ \
2 8
 4
/ \
2 8
/\ \
1 3 6

[图片上传失败...(image-28c9ec-1702866474149)]

通过以上三步,可确定三个节点 :1.树的根节点、2.左子树根节点、3.右子树根节点。

根据「分治算法」思想,对于树的左、右子树,仍可复用以上方法划分子树的左右子树。

分治算法解析:

image.png
class Solution {
    int[] preorder;
    HashMap<Integer, Integer> dic = new HashMap<>();
    public TreeNode buildTree(int[] preorder, int[] inorder) {
        this.preorder = preorder;
        for(int i = 0; i < inorder.length; i++)
            dic.put(inorder[i], i);
        return recur(0, 0, inorder.length - 1);
    }
    TreeNode recur(int root, int left, int right) {
        if(left > right) return null;                          // 递归终止
        TreeNode node = new TreeNode(preorder[root]);          // 建立根节点
        int i = dic.get(preorder[root]);                       // 划分根节点、左子树、右子树
        node.left = recur(root + 1, left, i - 1);              // 开启左子树递归
        node.right = recur(root + i - left + 1, i + 1, right); // 开启右子树递归
        return node;                                           // 回溯返回根节点
    }
}
上一篇下一篇

猜你喜欢

热点阅读