题目链接:http://acm.pku.edu.cn/JudgeOnline/problem?id=1674
题意简述:给定序列,求用交换排序将其排成上升序列所用的交换次数。
解题思路:首先判断第一个位置的数,是否为1,否则swap(a[i],a[a[i]])直到第一个数为1,以此类推,后面同。(不会证明,当时tle后,第一反映就是这种算法。水过。。。)
代码:
本文介绍了一个简单的算法,用于计算通过交换排序将序列变为升序所需的最少交换次数。该方法逐个检查序列中的元素,如果当前位置的元素不是期望的值,则进行交换并累加次数。
题目链接:http://acm.pku.edu.cn/JudgeOnline/problem?id=1674
题意简述:给定序列,求用交换排序将其排成上升序列所用的交换次数。
解题思路:首先判断第一个位置的数,是否为1,否则swap(a[i],a[a[i]])直到第一个数为1,以此类推,后面同。(不会证明,当时tle后,第一反映就是这种算法。水过。。。)
代码:

被折叠的 条评论
为什么被折叠?