#ATarc165b. [ARC165B] Sliding Window Sort 2

[ARC165B] Sliding Window Sort 2

题目描述

给定一个由 11NN 的整数构成的排列 P=(P1,P2,,PN)P=(P_1,P_2,\dots,P_N) 和一个整数 KK

对于排列 PP,我们定义如下操作:

  • 选择一个满足 1iNK+11\leq i\leq N-K+1 的整数 ii,将 Pi,Pi+1,,Pi+K1P_i,P_{i+1},\dots,P_{i+K-1} 按升序排列。也就是说,设 Pi,Pi+1,,Pi+K1P_i,P_{i+1},\dots,P_{i+K-1} 升序排列后为 (x1,x2,,xK)(x_1,x_2,\dots,x_K),则对于每个 1jK1\leq j\leq K,用 xjx_j 替换 Pi+j1P_{i+j-1}

请你求出对 PP 恰好进行一次上述操作后,能够得到的排列中字典序最大的一个,并用空格分隔输出。

数列的字典序定义如下:设数列 S=(S1,S2,,SS)S=(S_1,S_2,\ldots,S_{|S|})T=(T1,T2,,TT)T=(T_1,T_2,\ldots,T_{|T|}),则 SS 的字典序小于 TT,当且仅当满足以下两条之一。这里 S,T|S|,|T| 分别表示 S,TS,T 的长度。

  1. S<T|S|<|T|(S1,S2,,SS)=(T1,T2,,TS)(S_1,S_2,\ldots,S_{|S|})=(T_1,T_2,\ldots,T_{|S|})
  2. 存在整数 1imin{S,T}1\leq i\leq \min\lbrace |S|,|T| \rbrace,使得以下两点都成立:
    • (S1,S2,,Si1)=(T1,T2,,Ti1)(S_1,S_2,\ldots,S_{i-1})=(T_1,T_2,\ldots,T_{i-1})
    • SiS_i 小于 TiT_i(按数值比较)。

输入格式

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

NN KK P1P_1 P2P_2 \dots PNP_N

输出格式

请输出对 PP 恰好进行一次操作后能得到的字典序最大的排列,数之间用空格分隔。

样例 1

输入

4 3
2 1 4 3

输出

2 1 3 4

样例 2

输入

5 1
3 1 4 2 5

输出

3 1 4 2 5

样例 3

输入

20 7
9 4 3 1 11 12 13 15 17 7 2 5 6 20 19 18 8 16 14 10

输出

9 4 3 1 11 12 13 15 17 7 2 5 6 8 18 19 20 16 14 10

说明/提示

限制

  • 1KN2×1051\leq K\leq N\leq 2\times 10^5
  • 1PiN1\leq P_i\leq N
  • (P1,P2,,PN)(P_1,P_2,\dots,P_N)11NN 的一个排列
  • 输入的所有值均为整数

样例解释 1

i=1i=1 时,操作的区间为 (P1,P2,P3)=(2,1,4)(P_1,P_2,P_3)=(2,1,4),升序排列后为 (1,2,4)(1,2,4),所以 P1,P2,P3P_1,P_2,P_3 分别变为 1,2,41,2,4,此时 P=(1,2,4,3)P=(1,2,4,3)
i=2i=2 时,操作的区间为 (P2,P3,P4)=(1,4,3)(P_2,P_3,P_4)=(1,4,3),升序排列后为 (1,3,4)(1,3,4),此时 P=(2,1,3,4)P=(2,1,3,4)
这两种结果中,字典序较大的是 (2,1,3,4)(2,1,3,4),因此答案为 (2,1,3,4)(2,1,3,4)

由 ChatGPT 4.1 翻译