ACM刷题之路(九)数论-逆序组 交换座位

简介: ACM刷题之路(九)数论-逆序组 交换座位

C 交换座位


时间限制(普通/Java):1000MS/3000MS          运行内存限制:65536KByte

总提交:185            测试通过:61

描述

学号分别为1,2,3,4,5,6,7,8的8位同学随机排成一排,现在想把他们按学号从小到大排序,在排序的时候每次只能其中的2位同学进行换位,请问最少需要几次这样的换位。

输入

输入有多组数据(组数至少20000),每组输入一个含有12345678的字符串。

输出

输出最少所需的交换次数。

样例输入

12345678

12365478

12345786

样例输出

0

1

2


分析:

由于数字只有8个数,所以可以暴力解决。

根据观察:

如果两个数需要对调,那么交换的次数为1;

如果三个数需要对调,那么交换的次数为2;

如果四个数需要对调,那么交换的次数为3;

...

观察可以得出:如果n个数需要对调,那么交换的次数为n-1;

所以我们只要通过搜索找出8个数字中有多少个“小组”。

比如12365487:有1、2、3、654、87 五大组,组员分别为1、1、1、3、2个人  所以交换次数等于0、0、0、2、1;

加起来就是三次。


AC代码如下:

1. #include<stdio.h>
2. #include<string.h>
3. #include<iostream>
4. using namespace std;
5. 
6. char a[9];
7. bool b[9];
8. int geshu;
9. void dfs(int x){
10.     b[x] = true;
11.     geshu++;
12. if (b[a[x] - '0'] == false)
13. dfs(a[x] - '0');
14. }
15. 
16. int main(){
17. while (gets(a + 1)){
18. int sum = 0, i, sum2 = 0;
19. memset(b, false, sizeof(b));
20. for (i = 1; i <= 8; i++){
21.             geshu = 0;
22. if (b[i] == false){
23.                 geshu = 0;
24. dfs(i);
25.             }
26. if (geshu > 1){
27.                 sum += geshu - 1;
28.             }
29.         }
30.         cout << sum << endl;
31.     }
32. return 0;
33. }
34.

 


相关文章
【2001NOIP普及组】T3. 求先序排列 试题解析
【2001NOIP普及组】T3. 求先序排列 试题解析
|
7月前
|
C++
【洛谷 P1047】[NOIP2005 普及组] 校门外的树 题解(位集合)
**NOIP2005普及组问题:**给定长度为$l$的马路,上面等距种植着树,需移除位于建造地铁区域的树。输入包含马路长度和区域数,以及各区域起止点,输出移树后剩余树的数量。样例输入:$l=500$, $m=3$,输出:$298$。$20\%$数据无区域重合,$1 \leq l \leq 10^4$,$1 \leq m \leq 100$。解决方案利用位集合(bitset)表示树的状态,遍历区域将树设为0,最后统计1的数量。AC代码使用C++实现。
36 0
|
7月前
|
C++
【洛谷 P1059】[NOIP2006 普及组] 明明的随机数 题解(集合)
**NOIP2006普及组题目**,明明需生成不重复的1-1000间随机整数,输入含两行:第一行是整数N(≤100),第二行是N个随机数。输出两行,第一行是唯一数的个数M,第二行是排序后的唯一数。示例:输入10个数含重复,输出8个不同数排序后结果。解题方法:利用C++的`set`进行去重和排序。
76 0
|
算法 测试技术 Android开发
LeetCode 周赛上分之旅 #39 结合中心扩展的单调栈贪心问题
学习数据结构与算法的关键在于掌握问题背后的算法思维框架,你的思考越抽象,它能覆盖的问题域就越广,理解难度也更复杂。在这个专栏里,小彭与你分享每场 LeetCode 周赛的解题报告,一起体会上分之旅。
69 1
ACM刷题之路(三)dfs+排列 第K个幸运排列
ACM刷题之路(三)dfs+排列 第K个幸运排列
[算法刷题题解笔记] 洛谷 P1003 [NOIP2011 提高组] 铺地毯 [枚举]
[算法刷题题解笔记] 洛谷 P1003 [NOIP2011 提高组] 铺地毯 [枚举]
ACM刷题之路(八)数论-取余 停车位划分
ACM刷题之路(八)数论-取余 停车位划分
|
C语言 C++
PTA团体程序设计天梯赛-练习集: L1-050 倒数第N个字符串 ( 15分 )
给定一个完全由小写英文字母组成的字符串等差递增序列,该序列中的每个字符串的长度固定为 L,从 L 个 a 开始,以 1 为步长递增。例如当 L 为 3 时,序列为 { aaa, aab, aac, ..., aaz, aba, abb, ..., abz, ..., zzz }。这个序列的倒数第27个字符串就是 zyz。对于任意给定的 L,本题要求你给出对应序列倒数第 N 个字符串。 输入格式: 输入在一行中给出两个正整数 L(2 ≤ L ≤ 6)和 N(≤105)。 输出格式: 在一行中输出对应序列倒数第 N 个字符串。题目保证这个字符串是存在的。 输入样例:
185 0
|
人工智能 移动开发
【蓝桥杯集训·每日一题】AcWing 3805. 环形数组
文章目录 一、题目 1、原题链接 2、题目描述 二、解题报告 1、思路分析 2、时间复杂度 3、代码详解 三、知识风暴 线段树
108 0

热门文章

最新文章