题解 | #重建二叉树#

重建二叉树

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

/**
 * 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) {
            return null;
        }
        if(pre.length ==0 ||vin.length == 0){
            return null;
        }
       TreeNode node = findNode(pre,0,pre.length - 1,vin,0,vin.length - 1);
        return node;
    }
    public  TreeNode findNode(int[] pre, int preStart, int preEnd, int[] middle, int middleStart, int middleEnd) {
        //根节点
        TreeNode node = new TreeNode(pre[preStart]);
      
        //中序遍历 找出左子树有多少个 左根右
        int rootIndex = 0;
        for (int i = middleStart; i <= middleEnd; i++) {
            if (node.val == middle[i]) {
                rootIndex = i;
                break;
            }
        }
        //  左子树
        int leftCount = rootIndex - middleStart;
        if(leftCount  > 0) {
            node.left = findNode(pre, preStart +1, preStart + leftCount, middle, middleStart, rootIndex-1);
        }
        int rightCount = middleEnd - rootIndex;
        if(rightCount > 0) {
            node.right = findNode(pre, preStart+leftCount+1, preEnd, middle,  rootIndex + 1, middleEnd);
        }
        return node;
    }
}
全部评论

相关推荐

思念SiN:你这里没有通过的主要原因应该是计算平均分数的时候,在你贴的代码的第23行: ```c b[i]=(sum-max-min)/(m-2); ``` 等式的右边实际上是两个`int`类型的变量在做除法,C语言里面得到的结果会是这个除法的整数部分,余数部分被舍弃了,也不会自动变成浮点数去做除法。所以虽然你使用了`b[i]`这个浮点数去接收结果,但是等式右边除法是先得到了一个整数,然后再被转换为浮点数再赋值给了`b[i]`。你可以按下面这样,在做除法之前,先进行类型转换,就能得到期望的结果: ```c b[i]=(float)(sum-max-min)/(float)(m-2); ```
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务