一、學習要點:
這篇博客講的比較好:https://www.cnblogs.com/fstang/p/3754549.html
不斷填坑挖坑,填坑是用應有的值,挖去不匹配的值;
二、代碼:
class Solution
{
int firstMissingPositive(int A[],int n)
{
for(i=0;i<n;i++)
{
if(A[i]==i+1)
{
continue;
}
int idx=A[i];
if(idx>0&&idx<=n&&A[idx-1]!=idx)
{
int temp=A[idx-1];
A[idx-1]=idx;
idx=temp;
}
}
}
};