#ATarc180b. [ARC180B] Improve Inversions

[ARC180B] Improve Inversions

题目描述

给定一个 (1,2,,N)(1,2,\cdots,N) 的排列 P=(P1,P2,,PN)P=(P_1,P_2,\cdots,P_N),以及一个整数 KK

你可以进行如下操作 00 次或多次:

  • 选择整数 l,rl,r1l<rN1\leq l<r\leq N),但需满足以下所有条件:
    • KrlK\leq r-l
    • 当前 Pl>PrP_l>P_r
    • 之前从未选择过同一组 (l,r)(l,r)
  • 然后交换 PlP_lPrP_r 的值。

你希望最大化操作次数。请给出一种实现方法。

输入格式

输入通过标准输入按以下格式给出:

NN KK P1P_1 P2P_2 \cdots PNP_N

输出格式

请按以下格式输出答案:

mm l1l_1 r1r_1 l2l_2 r2r_2 \vdots lml_m rmr_m

其中 mm 是最大操作次数,li,ril_i,r_i 是第 ii 次操作选择的 l,rl,r。如果有多种方案,输出任意一种即可。

样例 1

输入

3 1
3 2 1

输出

3
2 3
1 3
1 2

样例 2

输入

5 4
1 4 3 2 5

输出

0

样例 3

输入

4 2
4 1 2 3

输出

2
1 4
1 3

样例 4

输入

10 5
8 7 6 10 9 3 1 5 2 4

输出

15
3 8
2 8
3 10
3 9
1 8
2 10
2 9
2 7
1 10
5 10
1 9
4 10
4 9
1 7
1 6

说明/提示

限制条件

  • 2N5002\leq N\leq 500
  • 1KN11\leq K\leq N-1
  • (P1,P2,,PN)(P_1,P_2,\cdots,P_N)(1,2,,N)(1,2,\cdots,N) 的一个排列
  • 输入的所有值均为整数

样例解释 1

在本例中,最大操作次数为 33。输出样例的操作过程如下:

  • 11 次操作:选择 (l,r)=(2,3)(l,r)=(2,3)1321\leq 3-2P2>P3P_2>P_3,且未选过 (2,3)(2,3),满足条件。交换 P2,P3P_2,P_3P=(3,1,2)P=(3,1,2)
  • 22 次操作:选择 (l,r)=(1,3)(l,r)=(1,3)1311\leq 3-1P1>P3P_1>P_3,且未选过 (1,3)(1,3),满足条件。交换 P1,P3P_1,P_3P=(2,1,3)P=(2,1,3)
  • 33 次操作:选择 (l,r)=(1,2)(l,r)=(1,2)1211\leq 2-1P1>P2P_1>P_2,且未选过 (1,2)(1,2),满足条件。交换 P1,P2P_1,P_2P=(1,2,3)P=(1,2,3)

由 ChatGPT 4.1 翻译