题目描述
给定一个由 1 到 N 的整数构成的排列 P=(P1,P2,…,PN) 和一个整数 K。
对于排列 P,我们定义如下操作:
- 选择一个满足 1≤i≤N−K+1 的整数 i,将 Pi,Pi+1,…,Pi+K−1 按升序排列。也就是说,设 Pi,Pi+1,…,Pi+K−1 升序排列后为 (x1,x2,…,xK),则对于每个 1≤j≤K,用 xj 替换 Pi+j−1。
请你求出对 P 恰好进行一次上述操作后,能够得到的排列中字典序最大的一个,并用空格分隔输出。
数列的字典序定义如下:设数列 S=(S1,S2,…,S∣S∣),T=(T1,T2,…,T∣T∣),则 S 的字典序小于 T,当且仅当满足以下两条之一。这里 ∣S∣,∣T∣ 分别表示 S,T 的长度。
- ∣S∣<∣T∣ 且 (S1,S2,…,S∣S∣)=(T1,T2,…,T∣S∣)。
- 存在整数 1≤i≤min{∣S∣,∣T∣},使得以下两点都成立:
- (S1,S2,…,Si−1)=(T1,T2,…,Ti−1)。
- Si 小于 Ti(按数值比较)。
输入格式
输入以如下格式从标准输入读入:
N K P1 P2 … PN
输出格式
请输出对 P 恰好进行一次操作后能得到的字典序最大的排列,数之间用空格分隔。
样例 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
说明/提示
限制
- 1≤K≤N≤2×105
- 1≤Pi≤N
- (P1,P2,…,PN) 是 1 到 N 的一个排列
- 输入的所有值均为整数
样例解释 1
当 i=1 时,操作的区间为 (P1,P2,P3)=(2,1,4),升序排列后为 (1,2,4),所以 P1,P2,P3 分别变为 1,2,4,此时 P=(1,2,4,3)。
当 i=2 时,操作的区间为 (P2,P3,P4)=(1,4,3),升序排列后为 (1,3,4),此时 P=(2,1,3,4)。
这两种结果中,字典序较大的是 (2,1,3,4),因此答案为 (2,1,3,4)。
由 ChatGPT 4.1 翻译