BiruLyu
8/1/2017 - 12:02 AM

41. First Missing Positive(#).java

public class Solution {
    public int firstMissingPositive(int[] nums) {

        for(int i=0;i<nums.length;i++){
        	while(nums[i]!=i+1){
                int sindex = nums[i]-1;
        		if(sindex<0||sindex>=nums.length)
        			break;
        		if(nums[i]==nums[sindex])
        			break;
        		int tmp = nums[i];
        		nums[i] = nums[sindex];
        		nums[sindex] = tmp;
        	}
        }
        for(int i=0;i<nums.length;i++){
        	if(nums[i]!=i+1)
        		return i+1;
        }
        return nums.length+1;
    }
}
public class Solution {
    private void swap(int[] nums, int a, int b) {
        int temp = nums[a];
        nums[a] = nums[b];
        nums[b] = temp;
    }
    public int firstMissingPositive(int[] nums) {
        //if (nums == null || nums.length < 1) return 1;
        int len = nums.length;
        for (int i = 0; i < len; i++) {
            //while (nums[i] > 0 && nums[i] <= len && nums[i] != i + 1) {
            while (nums[i] > 0 && nums[i] <= len && nums[nums[i] - 1] != nums[i]) { // []
                swap(nums, i, nums[i] - 1);
            }
        }
        for (int i = 0; i < len; i++) {
            if (nums[i] != i + 1) {
                return i + 1;
            }
        }
        return len + 1;
        
    }
}