列表

详情


OR91. 排序次数

描述

小摩有一个N个数的数组,他想将数组从小到大 排好序,但是萌萌的小摩只会下面这个操作:
任取数组中的一个数然后将它放置在数组的最后一个位置。
问最少操作多少次可以使得数组从小到大有序?

输入描述

首先输入一个正整数N,接下来的一行输入N个整数。(N <= 50, 每个数的绝对值小于等于1000)

输出描述

输出一行操作数

示例1

输入:

4
19 7 8 25

输出:

2

说明:

19放到最后,25放到最后,两步完成从小到大排序

原站题解

C 解法, 执行用时: 2ms, 内存消耗: 236KB, 提交时间: 2019-05-16

#include<stdio.h>
   
int main()
{
    int N;
    scanf("%d",&N);
    int v[N],v_sort[N];
    for(int i=0;i<N;i++)
    {
        scanf("%d",&v[i]);
        v_sort[i] = v[i];
    }
       
    //排序
    int tmp;
    for(int i=N-1;i>0;i--)
    {
        for(int j=0;j<i;j++)
        {
            if(v_sort[j]>v_sort[j+1])
            {
                tmp = v_sort[j];
                v_sort[j] = v_sort[j+1];
                v_sort[j+1] = tmp;
            }
        }
    }
       
    int k=0,num;
    for(int i=0;i<N;i++)
    {
        if(v[i]==v_sort[k])
        {
            k++;
        }
    }
    num = N - k;
    printf("%d\n",num);
       
    return 0;
}

C 解法, 执行用时: 2ms, 内存消耗: 344KB, 提交时间: 2019-05-13

#include<stdio.h>
  
int main()
{
    int N;
    scanf("%d",&N);
    int v[N],v_sort[N];
    for(int i=0;i<N;i++)
    {
        scanf("%d",&v[i]);
        v_sort[i] = v[i];
    }
      
    //排序
    int tmp;
    for(int i=N-1;i>0;i--)
    {
        for(int j=0;j<i;j++)
        {
            if(v_sort[j]>v_sort[j+1])
            {
                tmp = v_sort[j];
                v_sort[j] = v_sort[j+1];
                v_sort[j+1] = tmp;
            }
        }
    }
      
    int k=0,num;
    for(int i=0;i<N;i++)
    {
        if(v[i]==v_sort[k])
        {
            k++;
        }
    }
    num = N - k;
    printf("%d\n",num);
      
    return 0;
}

上一题