输入某二叉树的前序遍历和中序遍历的结果,请重建该二叉树。假设输入的前序遍历和中序遍历的结果中都不含重复的数字。
例如,给出
前序遍历 preorder = [3,9,20,15,7]
中序遍历 inorder = [9,3,15,20,7]
返回如下的二叉树:
3
/
9 20
/
15 7
限制:
0 <= 节点个数 <= 5000
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/zhong-jian-er-cha-shu-lcof
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
class Solution {
private Map<Integer,Integer> hashMap;
public TreeNode tree(int[] preorder, int[] inorder,int preorder_left,int preorder_right,int inorder_left,int inorder_right){
if (preorder_left>preorder_right){
return null;
}
//前序第一个结点是根节点
int preorder_root=preorder_left;
//找到根节点在中序的位置
int inorder_root=hashMap.get(preorder[preorder_root]);
//建树,根节点
TreeNode treeNode=new TreeNode(preorder[preorder_root]);
//左子树数目,中序遍历根节点左边的都是左子树
int tree_left_size=inorder_root-inorder_left;
//递归左子树,并连接到根节点
// 先序遍历中「从 左边界+1 开始的 size_left_subtree」个元素就对应了中序遍历中「从 左边界 开始到 根节点定位-1」的元素
treeNode.left=tree(preorder,inorder,preorder_left+1,preorder_left+tree_left_size,inorder_left,inorder_root-1);
//递归右子树,并连接到根节点
treeNode.right=tree(preorder,inorder,preorder_left+tree_left_size+1,preorder_right,inorder_root+1,inorder_right);
return treeNode;
}
public TreeNode buildTree(int[] preorder, int[] inorder) {
//映射结点位置
int n=preorder.length;
hashMap=new HashMap<>();
for (int i=0;i<n;i++){
hashMap.put(inorder[i],i);
}
return tree(preorder,inorder,0,n-1,0,n-1);
}
}