#ATagc001f. [AGC001F] Wide Swap

[AGC001F] Wide Swap

题目描述

给定一个长度为 NN 的数列 P1PNP_1\ldots P_N,该数列是 1N1\sim N 的一个排列。

你可以对该数列进行如下操作任意次:

  • 选择整数 i,ji, j,满足 1i<jN1 \leq i < j \leq N
  • 交换 PiP_iPjP_j 的值。
  • 但必须满足 jiKj - i \geq KPiPj=1|P_i - P_j| = 1

请你求出通过上述操作能够得到的字典序最小的数列。

输入格式

输入以如下格式从标准输入读入:

NN KK P1P_1 P2P_2 ...... PNP_N

输出格式

输出通过题目中操作能够得到的字典序最小的数列。

样例 1

输入

4 2
4 2 3 1

输出

2
1
4
3

样例 2

输入

5 1
5 4 3 2 1

输出

1
2
3
4
5

样例 3

输入

8 3
4 5 7 8 3 1 2 6

输出

1
2
6
7
5
3
4
8

说明/提示

限制条件

  • 2N500, ⁣0002 \leq N \leq 500,\!000
  • 1KN11 \leq K \leq N-1
  • PP1,2,...,N1, 2, ..., N 的一个排列。

样例解释 1

可以按如下步骤进行操作:

  • 4 2 3 14\ 2\ 3\ 1
  • 4 1 3 24\ 1\ 3\ 2
  • 3 1 4 23\ 1\ 4\ 2
  • 2 1 4 32\ 1\ 4\ 3

由 ChatGPT 4.1 翻译