Related
In following contests:
塔子哥是一个学生,他最近学习的时候遇到了一个题目,题目给定了一个长度为 n 的排列吗,题目要求将这个排列的前 k 个数排列成一个长度为 k 的排列,但是题目规定只能进行相邻两个数的交换操作,题目问最少需要多少次上述操作才能满足题目要求?
塔子哥思考了很久还是不会,他现在想请教你,想让你帮忙解决一下这个问题。
解决这个问题的关键在于如何选择交换哪两个数,我们可以观察到,为了最小化交换操作的次数,我们应该优先将大于k的数移出前k个数,同时将1到k的数移入前k个数。
由于本题只能交换相邻两个数字,因此,我们可以首先找出前k个数中大于k的数的位置,然后找出后n−k个数中1到k的数的位置,然后计算这两个位置的差值的绝对值,这个差值就是需要的最少交换次数。
具体实现我们可以使用两个数组去分别记录[1,k]的下标和[k+1,n]的下标,然后根据上述计算规则去计算
In following contests: