coderforce 489ASwapSort

题意:交换数组元素,取最少步数,排好序。输出交换元素的位置。
#include<stdio.h>
#include<string.h>
#include<algorithm>
using namespace std;
const int maxm=1e4+10;
int a[maxm];
int main()
{
    int n;
    while(scanf("%d",&n)!=EOF)
    {
        for(int i=0;i<n;i++)
        {
            scanf("%d",&a[i]);
        }
        printf("%d\n",n);
        for(int i=0;i<n;i++)
        {
            int id=i;
            for(int j=i+1;j<n;j++)
            {
                if(a[id]>a[j])
                {
                    id=j;
                }
            }
            printf("%d %d\n",i,id);
            swap(a[id],a[i]);
        }
    }
    return 0;
}

你可能感兴趣的:(coderforce 489ASwapSort)