题目: 缺失的第一个正数

来自智得网
跳转至: 导航、​ 搜索

分析

将数组中的数字放在对应的位置上,例如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;
    }
}