UVa 1611 (排序 模拟) Crane

时间:2023-03-08 19:36:06

假设数字1~i-1已经全部归位,则第i到第n个数为无序区间。

如果i在无序区间的前半段,那么直接将i换到第i个位置上。

否则先将i换到无序区间的前半段,再将i归位。这样每个数最多操作两次即可归位。

 #include <bits/stdc++.h>
using namespace std; const int maxn = + ;
int a[maxn];
vector<pair<int, int> > ans; void op(int L, int R)
{
ans.push_back(make_pair(L, *R-L-));
int t = R - L;
for(int i = L; i < R; i++) swap(a[i], a[i+t]);
} int main()
{
//freopen("in.txt", "r", stdin); int T; scanf("%d", &T);
while(T--)
{
int n; scanf("%d", &n);
for(int i = ; i <= n; i++) scanf("%d", &a[i]);
ans.clear();
for(int i = ; i < n; i++)
{
if(a[i] == i) continue;
int j;
for(j = i+; j <= n; j++) if(a[j] == i) break;
if(j - i <= n - j + ) op(i, j);
else
{
int t = (n - i + ) / ;
op(n-*t+, n-t+);
i--;
}
}
int sz = ans.size();
printf("%d\n", sz);
for(int i = ; i < sz; i++) printf("%d %d\n", ans[i].first, ans[i].second);
} return ;
}

代码君