public static int firstMissingPositive1(int[] nums) { int length = nums.length;
// 转成正数,注意用下标,否则不生效 for (int i = 0; i < length; i++) { if (nums[i] <= 0) { nums[i] = length + 1; } } for (int i = 0; i < length; i++) { int num = Math.abs(nums[i]); if (num <= length) { nums[num - 1] = -Math.abs(nums[num - 1]); } } for (int i = 0; i < length; i++) { if (nums[i] > 0) { return i + 1; } }
return length + 1; }
public static int firstMissingPositive(int[] nums) {
int length = nums.length; for (int i = 0; i < length; i++) { while (nums[i] > 0 && nums[i] < length && nums[nums[i] - 1] != nums[i]) { inttemp = nums[nums[i] - 1]; nums[nums[i] - 1] = nums[i]; nums[i] = temp; } }
for (int i = 0; i < length; i++) { if (nums[i] != i + 1) { return i + 1; } } return length + 1; }