#ATarc121c. [ARC121C] Odd Even Sort

[ARC121C] Odd Even Sort

题目描述

给定一个由 (1,2,,N)(1,2,\ldots,N) 组成的排列 pp。初始时,pp 的第 nn 项为 pnp_n

你的目标是在不超过 N2N^2操作 内将 pp 排成升序。你可以通过如下方式对 pp 进行操作:

  • 在第奇数次操作时,你可以选择 11N1N-1 之间的奇数 nn,并交换 pnp_npn+1p_{n+1}
  • 在第偶数次操作时,你可以选择 22N1N-1 之间的偶数 nn,并交换 pnp_npn+1p_{n+1}

在本题的限制下,总是可以实现目标。请给出一种满足条件的操作序列。

TT 组测试数据,请分别输出每组的答案。

输入格式

输入通过标准输入给出,格式如下:

TT
case1\mathrm{case}_1
\vdots
caseT\mathrm{case}_T

每组测试数据格式如下:

NN p1p_1 \cdots pNp_N

输出格式

对于每组测试数据,按输入顺序输出如下格式的答案:

MM a1a_1 \cdots aMa_M

MM 表示操作序列的长度,aia_i 表示第 ii 次操作选择的整数。

只要输出的操作序列能使每组测试数据的 pp 排成升序,即为正确答案。

样例 1

输入

2
5
2 1 3 5 4
2
1 2

输出

2
1 4
0

说明/提示

限制

  • 所有输入均为整数。
  • 1T2501 \leq T \leq 250
  • 2N5002 \leq N \leq 500
  • 1piN1 \leq p_i \leq N
  • pp(1,2,,N)(1,2,\ldots,N) 的一个排列。
  • 单个输入文件中所有 NN 的总和不超过 500500

样例解释 1

  • 对于第 1 组测试数据:
    • 第 1 次操作选择 11,此时 pp 变为 (1,2,3,5,4)(1,2,3,5,4)
    • 第 2 次操作选择 44,此时 pp 变为 (1,2,3,4,5)(1,2,3,4,5)
    • (1,4)(1,4) 是一个合法的操作序列,但 (4,1)(4,1) 不是。
    • 也可以不进行任何操作,并且不要求操作次数最少。

由 ChatGPT 4.1 翻译