Given an unsorted integer array, find the first missing positive integer.
For example,
Given
and
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.
无序数组的题目如果要O(n)解法往往要用到hash table,但这题要求constant space。所以可以用数组本身作为一个"hash table":A[0] = 1, A[1] = 2, .... A[n-1] = n。目标是尽可能将数字i放到数组第i-1个位置。
扫描数组中每个数:
1. 如果A[i]<1或者A[i]>n。说明A[i]一定不是first missing positive。跳过
2. 如果A[i] = i+1,说明A[i]已经在正确的位置,跳过
3. 如果A[i]!=i+1,且0<A[i]<=n,应当将A[i]放到A[A[i]-1]的位置,所以可以交换两数。
这里注意,当A[i] = A[A[i]-1]时会陷入死循环。这种情况下直接跳过。
扫描数组中每个数:
1. 如果A[i]<1或者A[i]>n。说明A[i]一定不是first missing positive。跳过
2. 如果A[i] = i+1,说明A[i]已经在正确的位置,跳过
3. 如果A[i]!=i+1,且0<A[i]<=n,应当将A[i]放到A[A[i]-1]的位置,所以可以交换两数。
这里注意,当A[i] = A[A[i]-1]时会陷入死循环。这种情况下直接跳过。
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | class Solution { public: int firstMissingPositive(int A[], int n) { int i=0; while(i<n) { if(A[i]!=i+1 && A[i]>0 && A[i]<=n && A[i]!=A[A[i]-1]) swap(A[i],A[A[i]-1]); else i++; } for(int i=0; i<n; i++) { if(A[i]!=i+1) return i+1; } return n+1; } }; | 
 
请教下,f(A[i]!=i+1 && A[i]>0 && A[i]<=n && A[i]!=A[A[i]-1])
ReplyDeleteswap(A[i],A[A[i]-1]);
最坏情况要全loop, 时间复杂度O(n),套上外边的loop: worst time complexity = O(n^2) ?
每 swap 一次, 必然有一个数 in position, 所以最多 n 次 swap
ReplyDelete