题目: 缺失的第一个正数
来自智得网
分析
将数组中的数字放在对应的位置上,例如1放置在位置1,2放在位置2,如果超出数组长度,则肯定不是最小正整数。
题解
public class Solution {
public int solute(int[] nums){
int n = nums.length;
for(int i = 0;i < n; i ++){
while(nums[i] > 0 && nums[i] <= n && nums[nums[i] - 1] != nums[i]){
int tmp = nums[nums[i] - 1];
nums[nums[i] - 1] = nums[i];
nums[i] = tmp;
}
}
for(int i = 0;i < n; i ++){
if(nums[i] != i + 1){
return i + 1;
}
}
return n + 1;
}
}