Time Limit: 1 second

Memory Limit: 128 MB

【问题描述】

给定一个数列{an},这个数列满足ai≠aj(i≠j),现在要求你把这个数列从小到大排序,每次允许你交换其中任意一对数,请问最少需要几次交换?

【输入格式】

第一行,正整数n (n<=100,000)。 以下若干行,一共n个数,用空格分隔开,表示数列{an},任意-231<ai<231。 <="" p="">

【输出格式】

只有一行,包含一个数,表示最少的交换次数。

Sample Input

8
8 23 4 16 77 -5 53 100

Sample Output

5

【题解】

把所有的数字从小到大排序。

然后记录这个数字它原本的位置在哪里。

比如样例的输入。

最后排序的结果是

-5,4,8,16,23,53,77,100

然后它们原来的位置是

6 3 1 4 2 7 5 8

我们这样。

从第一个元素开始。

它原来的位置是6.

现在6位置上的元素,它原来的位置是7;

而现在7位置上的元素它原来的位置是5;

现在5位置上的元素它原来的位置是2;

现在2位置上的元素它原来的位置是3;

而现在3位置上的元素它原来的位置是1;

至此我们找到了一个循环。如下。

这里的箭头起点元素表示终点元素原来的位置;

那我们可以这样。把原来的无序序列。

位置1和位置6交换。这样满足排序后位置1上的元素来自原来的位置6;

现在6位置上是1位置上的元素。

然后位置6和位置7交换。

这样满足位置6上的元素来自位置7;

然后位置7变成了1位置上的元素。

然后位置7和位置5交换。同样满足了位置7上的元素来自位置5.

然后位置5变成了1位置上的元素。

然后位置2和位置5交换。这样满足了位置5上的元素是来自位置2;

然后位置2变成了1位置上的元素。

然后位置2和位置3交换。因为此时位置2上的元素是1位置上的元素。

所以交换后位置3上的元素上是来自位置1的。而这满足了这个循环节。

然后所需要的交换次数就是箭头的个数。也即节点个数减1;

位置4上的元素还是从位置4来的。无需交换。

【代码】

#include <cstdio>
#include <cstring>
#include <algorithm> struct data //是结构体的话,会连同pre在排序的时候一起改变
{
int shuju;
int pre;
}; int n;
data a[100001];
__int64 ans = 0; void input_data()
{
scanf("%d", &n); //输入n个数字
for (int i = 1; i <= n; i++)
scanf("%d", &a[i].shuju), a[i].pre = i;//记录数据同时记录它原本的位置。一开始都在原位
} int cmp(const data &a, const data &b) //sort函数的比较函数。
{
if (b.shuju > a.shuju)//按照数据的大小升序排序
return 1;
return 0;
} void get_ans()
{
bool used[100001];
memset(used, false, sizeof(used));//判断之前有没有计算过
for (int i = 1;i <= n;i++)
if (!used[i]) //如果之前没有计算过。
{
int tot = 0;
int k = i;
while (!used[k])//一直找它原来的位置
{
used[k] = true;//同时记录已经计算过。
k = a[k].pre;
tot++;//节点个数递增
}
ans += tot - 1;//按照上面的题解。答案就是节点个数-1(也即边的个数);
}
} void output_ans()
{
printf("%I64d", ans);//输出答案
} int main()
{
input_data();
std::sort(a + 1, a + 1 + n, cmp);//没有加using namespace std;就要在前面加std::
get_ans();
output_ans();
return 0;
}

【u002】数列排序(seqsort)的更多相关文章

  1. 洛谷——P1327 数列排序

    P1327 数列排序 题目描述 给定一个数列{an},这个数列满足ai≠aj(i≠j),现在要求你把这个数列从小到大排序,每次允许你交换其中任意一对数,请问最少需要几次交换? 输入输出格式 输入格式: ...

  2. luogu 1327 数列排序 & 2017 ACM-ICPC 亚洲区(南宁赛区)网络赛 J题 循环节

    luogu 1327 数列排序 题意 给定一个数列\(\{an\}\),这个数列满足\(ai≠aj(i≠j)\),现在要求你把这个数列从小到大排序,每次允许你交换其中任意一对数,请问最少需要几次交换? ...

  3. 洛谷 P1327 数列排序

    P1327 数列排序 题目描述 给定一个数列{an},这个数列满足ai≠aj(i≠j),现在要求你把这个数列从小到大排序,每次允许你交换其中任意一对数,请问最少需要几次交换? 输入输出格式 输入格式: ...

  4. lqb 基础练习 数列排序 (sort的使用)

    基础练习 数列排序 时间限制:1.0s   内存限制:512.0MB     问题描述 给定一个长度为n的数列,将这个数列按从小到大的顺序排列.1<=n<=200 输入格式 第一行为一个整 ...

  5. 蓝桥杯 C语言 基础训练 数列排序

    问题描述 给定一个长度为n的数列,将这个数列按从小到大的顺序排列.1<=n<=200 输入格式 第一行为一个整数n. 第二行包含n个整数,为待排序的数,每个整数的绝对值小于10000. 输 ...

  6. [蓝桥] 基础练习 数列排序(java)

    问题描述 给定一个长度为n的数列,将这个数列按从小到大的顺序排列.1<=n<=200 输入格式 第一行为一个整数n. 第二行包含n个整数,为待排序的数,每个整数的绝对值小于10000. 输 ...

  7. luogu P1327 数列排序

    题目描述 给定一个数列{an},这个数列满足ai≠aj(i≠j),现在要求你把这个数列从小到大排序,每次允许你交换其中任意一对数,请问最少需要几次交换? 输入格式 第一行,正整数n (n<=10 ...

  8. 蓝桥杯BASIC-13 数列排序

    问题描述 给定一个长度为n的数列,将这个数列按从小到大的顺序排列.1<=n<=200 输入格式 第一行为一个整数n. 第二行包含n个整数,为待排序的数,每个整数的绝对值小于10000. 输 ...

  9. 蓝桥网试题 java 基础练习 数列排序

    ---------------------------------------------------------------------------------------------------- ...

随机推荐

  1. Win8.1恢复这台电脑里的6个文件夹

    平台:win8.1 问题:网络下载的ghost版8.1,装好后“这台电脑”里没有6个常用的文件夹. 解决:导入下列注册表项即可 Windows Registry Editor Version 5.00 ...

  2. 随手记录---transform 属性

    其实平时很少用到transform属性,一些放大缩小用width.height可以改变,一些位置变换,更是有margin,而一些旋转.2D.3D变换也不怎么能用得到.不过最近接触了一些图片的缩放,觉得 ...

  3. BZOJ4196: [Noi2015]软件包管理器(树链剖分)

    Description Linux用户和OSX用户一定对软件包管理器不会陌生.通过软件包管理器,你可以通过一行命令安装某一个软件包,然后软件包管理器会帮助你从软件源下载软件包,同时自动解决所有的依赖( ...

  4. BZOJ2160: 拉拉队排练(Manacher)

    Description 艾利斯顿商学院篮球队要参加一年一度的市篮球比赛了.拉拉队是篮球比赛的一个看点,好的拉拉队往往能帮助球队增加士气,赢得最终的比赛.所以作为拉拉队队长的楚雨荨同学知道,帮助篮球队训 ...

  5. django 简单会议室预约(6)

    后台完了现在来看前端,前端用了一个bootstrap框架,看起来能好看点 先看一下文件结构:在djapp里创建了两个文件夹templates和static templates里面是要显示的页面,sta ...

  6. uiautomator_python使用汇总

    1.判断按钮状态 if d(resourceId="id",enabled=False): #判断当前按钮是否为未激活状态,为True则为激活状态2.获取toast提示语 d.to ...

  7. Scala具体解释---------数组、元组、映射

    一.数组 1.定长数组 声明数组的两种形式: 声明指定长度的数组 val 数组名= new Array[类型](数组长度) 提供数组初始值的数组,无需newkeyword Scala声明数组时.须要带 ...

  8. Cocos2d-x学习笔记(一)HelloWorld

    原创文章,转载请注明出处:http://blog.csdn.net/sfh366958228/article/details/38656755 前言 正式来公司实习已有一月,前一月主要是看了<C ...

  9. JS学习笔记 - 面向对象

    类.对象类:模子对象:产品(成品) 蛋糕(对象) 模子(类) Array 类 arr 对象 Array.push(); 错 arr.push(); 对 new arr(); 错 原型prototype ...

  10. oracle exp 备份脚本

    #!/bin/bash#Oracle 环境变量 NLS_LANG=AMERICAN_AMERICA.AL32UTF8 ORACLE_SID=zgw ORACLE_BASE=/opt/oracle OR ...