题解 | #重建二叉树#

重建二叉树

https://www.nowcoder.com/practice/8a19cbe657394eeaac2f6ea9b0f6fcf6

import java.util.*;
import java.util.HashMap;
import java.util.Map;
/**
 * 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) {

        if(pre==null||vin==null||pre.length != vin.length){
            return null;
        }
        Map<Integer,Integer> map1 = new HashMap<>();
        for(int i=0;i<vin.length;i++){
            map1.put(vin[i],i);
        }


        TreeNode head = TreeFun(pre,0,pre.length-1,vin,0,vin.length-1,map1);
        return head;

        
    }

    public static TreeNode TreeFun(int[] pre, int l1,int r1,int[] vin,int l2,int r2,Map<Integer,Integer> map){     
        if(l1>r1){
            return null;

        }

        TreeNode head = new TreeNode(pre[l1]);
        if(l1==r1){
            return head;
        }

        int find = map.get(pre[l1]);


        head.left = TreeFun(pre,l1+1,find-l2+l1,vin,l2,find-1,map);
        head.right = TreeFun(pre,find-l2+l1+1,r1,vin,find+1,r2,map);
        return head;


    }
}

全部评论

相关推荐

勤奋努力的椰子这就开摆:美团骑手在美团工作没毛病
投递美团等公司10个岗位
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务