AT_abc350_c [ABC350C] Sort
题目描述
给定一个是 $ (1,2,\ldots,N) $ 的排列的数列 $ A=(A_1,\ldots,A_N) $。
你可以进行 $ 0 $ 次到 $ N-1 $ 次操作,将 $ A $ 变为 $ (1,2,\ldots,N) $。
- 操作:可以自由选择满足 $ 1\leq i < j \leq N $ 的整数对 $ (i,j) $,交换 $ A $ 的第 $ i $ 个和第 $ j $ 个元素。
在题目给定的限制条件下,总是可以将 $ A $ 变为 $ (1,2,\ldots,N) $,这一点可以得到证明。
输入格式
输入从标准输入按以下格式给出。
> $ N $ $ A_1 $ $ \ldots $ $ A_N $
输出格式
设操作次数为 $ K $,请输出 $ K+1 $ 行。
第 $ 1 $ 行输出 $ K $。
第 $ l+1 $ 行($ 1\leq l \leq K $)输出第 $ l $ 次操作选择的整数 $ i,j $,用空格隔开。
只要满足题目条件,任意一种输出都被视为正确答案。
说明/提示
### 限制条件
- $ 2 \leq N \leq 2\times 10^5 $
- $ (A_1,\ldots,A_N) $ 是 $ (1,2,\ldots,N) $ 的一个排列
- 输入均为整数
### 样例解释 1
通过操作,数列会如下变化:
- 初始时 $ A=(3,4,1,2,5) $。
- 第 1 次操作交换第 1 个和第 3 个元素,$ A=(1,4,3,2,5) $。
- 第 2 次操作交换第 2 个和第 4 个元素,$ A=(1,2,3,4,5) $。
除此之外,以下输出也是正确答案:
```
4
2 3
3 4
1 2
2 3
```
由 ChatGPT 4.1 翻译