题解:CF384B Multitasking
思路
因为这道题并不需要求最小步数,只要在限定步数之内即可。那我们可以想到一个不是最优步数的做法。那就是每次交换相邻两个数字,这样做的话不仅可以保证排序结束后数组一定有序,且不会超出步数限制。但是需要注意的是升序和降序数字交换的前后顺序是不一样的。
AC Code
#include <bits/stdc++.h>
using namespace std;
int n, m, k;
int a;
int main() {
cin>>n>>m>>k;
for (int i = 1; i <= n; i++) {
for (int j = 1; j <= m; j++) {
cin>>a;
}
}
cout<<m * (m - 1) / 2<<"\n";
if (!k) {
for (int i = 1; i <= m; i++) {
for (int j = 1; j <= m - i; j++) {
cout<<j<<" "<<j+1<<"\n";
}
}
} else {
for (int i = 1; i <= m; i++) {
for (int j = m; j >= i + 1; j--) {
cout<<j<<" "<<j-1<<"\n";
}
}
}
return 0;
}