首页 > 其他 > 详细

First Missing Positive

时间:2015-06-12 02:11:47      阅读:248      评论: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.

?

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;
    }
}

?

First Missing Positive

原文:http://hcx2013.iteye.com/blog/2218750

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