关闭

插入排序

226人阅读 评论(0) 收藏 举报
分类:


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);
   }
}

0
0

猜你在找
【直播】机器学习&数据挖掘7周实训--韦玮
【套餐】系统集成项目管理工程师顺利通关--徐朋
【直播】3小时掌握Docker最佳实战-徐西宁
【套餐】机器学习系列套餐(算法+实战)--唐宇迪
【直播】计算机视觉原理及实战--屈教授
【套餐】微信订阅号+服务号Java版 v2.0--翟东平
【直播】机器学习之矩阵--黄博士
【套餐】微信订阅号+服务号Java版 v2.0--翟东平
【直播】机器学习之凸优化--马博士
【套餐】Javascript 设计模式实战--曾亮
查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:30847次
    • 积分:1477
    • 等级:
    • 排名:千里之外
    • 原创:120篇
    • 转载:16篇
    • 译文:0篇
    • 评论:0条