插入排序

转载 2015年07月08日 00:13:10


Description

每次选择序列最左边的数,然后将其插入到序列中任意一个位置。求至少需要重复进行多少次上述操作,才可以将序列变为一个递增序列。

Input

输入的第一行包含一个整数T (T > 0),表示一共有T组测试数据.
对于每组测试数据,第一行包含一个整数n (1 ≤ n ≤ 105),表示这个序列中一共有n个整数。第二行包含n个各不相同的整数(这些整数均在[1, 109]范围内),依次描述了这个序列中的各个数。

Output

对于每组测试数据,输出一个整数,表示至少需要重复进行多少次上述操作,才可以将这个序列变为一个递增序列。

Sample Input

3
3
1 2 3
3
1 3 2
5
1 5 4 3 2

Sample Output

0
2
4

HINT

Source

中南大学第八届大学生程序设计竞赛热身赛

思路:设m为以最后一个数结尾的连续的上升序列的长度。答案就是n-m。

例如:求m:如果是1 5 2 3 4,就是3 。  3,2,1就是1。

因为你只能最左边的数移动那么最优策略就是保持我说的最靠右的那段上升子列不动剩下的每个数动一下就行了。

#include<iostream>
#include<math.h>
using namespace std;
int a[100005];
main()
{
   int t;
   scanf("%d",&t);
   while(t--)
   {
     int n;
     scanf("%d",&n);
     for(int i=0;i<n;i++)
     {
      scanf("%d",&a[i]);
     }
     int ans=1;
     for(int i=n-2;i>=0;i--)
     {
      if(a[i]<a[i+1])ans++;
      else break;
     }
     printf("%d\n",n-ans);
   }
}

C++实现插入排序

  • 2017年11月02日 22:26
  • 712B
  • 下载

新手学习数据结构与算法---直接插入排序

直接插入排序: 时间复杂度:O(n^2) 一步一步记录自己成长的点滴,欢迎大家的建议。 //插入排序算法,以数组为实例,主要先理解算法 #include #define MAX 11...
  • zsjgs
  • zsjgs
  • 2011年10月16日 10:12
  • 372

插入排序(C语言实现)

  • 2014年11月30日 16:12
  • 926B
  • 下载

宁波赛 2010 T3 插入排序 线段树

【题目描述】     有依次排列的一列数a1,a2,a3,…,an-1,an。你可以随便把一个数拿出,插到最前面(当前第1个数a1前)、最后面(当前最后一个数an后面)、或者剩余数列中任意的相邻两个数...

插入排序的方法

  • 2013年07月10日 12:12
  • 31KB
  • 下载

直接插入排序的C实现

  • 2013年05月16日 11:20
  • 495B
  • 下载

c语言练习 插入排序 gcd求解

12月7随笔else if 语句使用时注意在判断中只进入一次。if(year % 4 ==0){ if(year % 100!= 0) } else if(year % 400 ==0) ...

插入排序源代码

  • 2013年07月31日 08:39
  • 585B
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:插入排序
举报原因:
原因补充:

(最多只允许输入30个字)