0
点赞
收藏
分享

微信扫一扫

BM40 重建二叉树

小沙坨 2022-03-31 阅读 46

1、题目

2、思路

给定节点数为 n 的二叉树的前序遍历和中序遍历结果,可以重建出该二叉树,我相信大家都可以手推出来过程吧,考过研的可以参考王道的数据结构,我记得本科课本里也有,这里主要关注的是代码逻辑。

3、代码

import java.util.*;
/**
 * Definition for binary tree
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode(int x) { val = x; }
 * }
 */
public class Solution {
    public TreeNode reConstructBinaryTree(int [] pre,int [] vin) {
         //数组长度为0的时候要处理
        if(pre.length == 0){
            return null;
        }
 
        int rootVal = pre[0];
 
        //数组长度仅为1的时候就要处理
        if(pre.length == 1){
            return new TreeNode(rootVal);
        }
 
        //我们先找到root所在的位置,确定好前序和中序中左子树和右子树序列的范围
        TreeNode root = new TreeNode(rootVal);
        int rootIndex = 0;
        for(int i=0;i<vin.length;i++){
            if(rootVal == vin[i]){
                rootIndex = i;
                break;
            }
        }
 
        //递归,假设root的左右子树都已经构建完毕,那么只要将左右子树安到root左右即可
        //这里注意Arrays.copyOfRange(int[],start,end)是[)的区间
        root.left = reConstructBinaryTree(Arrays.copyOfRange(pre,1,rootIndex+1),Arrays.copyOfRange(vin,0,rootIndex));
        root.right = reConstructBinaryTree(Arrays.copyOfRange(pre,rootIndex+1,pre.length),Arrays.copyOfRange(vin,rootIndex+1,vin.length));
 
        return root;

    }
    
}
举报

相关推荐

0 条评论