题解 | #数组中未出现的最小正整数#

数组中未出现的最小正整数

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

O(n),O(1)

    public int minNumberdisappered (int[] arr) {
        // write code here
        int minIdx = 0, n = arr.length;
        for (int i=0;i<n;i++){
            if (arr[i] > 0 && arr[i] <= n){
                arr[arr[i]-1] = arr[i];
                while (minIdx < n && arr[minIdx] == minIdx+1){
                    minIdx++;
                }
            }
        }
        return minIdx+1;
    }
全部评论

相关推荐

牛至超人:把哈工大,再加大加粗,看见闪闪发光的哈工大字样,面试官直接流口水
投递字节跳动等公司6个岗位
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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