First Missing Positive

来源:互联网 发布:京东云 阿里云 编辑:程序博客网 时间:2024/05/02 04:37

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.

每次交换使得一个数据num回到num-1的位置


class Solution {public:    int firstMissingPositive(int A[], int n) {                for(int i=0;i<n;){            if(A[i]!=i+1&&A[i]<=n&&A[i]>0&&A[A[i]-1]!=A[i]) {                int temp=A[A[i]-1];                A[A[i]-1]=A[i];                A[i]=temp;            }            else i++;        }        int ans;        for(ans=0;ans<n;ans++)            if(A[ans]!=ans+1) break;        return ans+1;    }};

0 0