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.
?
public class Solution {
    public int firstMissingPositive(int[] A) {
        int i = 0;
        while (i < A.length) {
        	if (A[i]!=(i+1) && A[i]>=1 && A[i]<=A.length && A[A[i]-1]!=A[i]) {
        		int t = A[i];
        		A[i] = A[A[i]-1];
        		A[t-1] = t;
        	} else {
        		i++;
        	}
        }
        for (i = 0; i < A.length; i++) {
        	if (A[i]!=(i+1)) {
        		return i+1;
        	}
        }
        return A.length+1;
    }
}
?
原文:http://hcx2013.iteye.com/blog/2218750