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