首页 > 其他 > 详细

41. First Missing Positive

时间:2016-12-03 07:55:05      阅读:208      评论:0      收藏:0      [点我收藏+]

Given an unsorted integer array, find the first missing positive integer.

For example,
Given [1,2,0] return 3,
and [3,4,-1,1] return 2.

Your algorithm should run in O(n) time and uses constant space.

example [-1,-2, 1,3];

i ++;  

i++ ;

i = 2  nums[2] = 1;  nums[nums[2] -1] = nums[0] exchange with nums[2] -> [1, -2, -1, 3]

i++;

i=3 nums[3] = 3 -> nums[2] exchange with nums[3] - > [1,-2,3,-1];

out of loop

anther loop  nums[0]= 1 got, nums[1] =-2 return i+1 -> 2

public class Solution {
    public int firstMissingPositive(int[] nums) {
        int i = 0 ;
        while(i < nums.length){
            if(nums[i] == i + 1 || nums[i] <= 0 || nums[i] > nums.length) i++;
            else if(nums[i] != nums[nums[i]-1]) swap(nums, i, nums[i]-1);
            else i++;
        }
         i = 0;
        while(i < nums.length && i+1 == nums[i]) i++;
        return i+1;
    }
    public void swap(int[] nums, int i, int j){
        int temp = nums[i];
        nums[i] = nums[j];
        nums[j] = temp;
    }
}

 

41. First Missing Positive

原文:http://www.cnblogs.com/joannacode/p/6127899.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!