#ATarc180e. [ARC180E] LIS and Inversion

[ARC180E] LIS and Inversion

题目描述

给定一个长度为 NN 的整数序列 A=(A1,A2,,AN)A=(A_1,A_2,\cdots,A_N)。这里,保证对于每个 ii,有 0Ai<i0\leq A_i < i

对于 (1,2,,N)(1,2,\cdots,N) 的一个排列 P=(P1,P2,,PN)P=(P_1,P_2,\cdots,P_N),定义其分数代价如下:

  • PP 的分数为 PP 的最长递增子序列的长度。
  • PP 的代价为满足以下条件的整数 ii1iN1\leq i\leq N)的个数:
    • 满足 j<ij<iPj>PiP_j>P_i 的整数 jj 的个数小于 AiA_i

对于每个 k=1,2,,Nk=1,2,\cdots,N,请解决下列问题:

  • 求分数至少为 kk 的排列 PP 的最小代价。

输入格式

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

NN A1A_1 A2A_2 \cdots ANA_N

输出格式

请按顺序输出 k=1,2,,Nk=1,2,\cdots,N 的答案。

样例 1

输入

4
0 1 2 1

输出

0 0 1 3

样例 2

输入

3
0 0 0

输出

0 0 0

样例 3

输入

5
0 1 2 3 4

输出

0 1 2 3 4

样例 4

输入

11
0 0 2 3 4 5 3 7 8 2 10

输出

0 0 0 1 2 3 4 5 7 8 9

说明/提示

限制条件

  • 1N2500001\leq N\leq 250000
  • 0Ai<i0\leq A_i < i
  • 输入的所有值均为整数

样例解释 1

对于每个 kk,满足条件的 PP 如下:

  • k=1k=1:取 P=(4,2,1,3)P=(4,2,1,3),此时 PP 的分数为 22,代价为 00
  • k=2k=2:取 P=(4,3,1,2)P=(4,3,1,2),此时 PP 的分数为 22,代价为 00
  • k=3k=3:取 P=(4,1,2,3)P=(4,1,2,3),此时 PP 的分数为 33,代价为 11
  • k=4k=4:取 P=(1,2,3,4)P=(1,2,3,4),此时 PP 的分数为 44,代价为 33

由 ChatGPT 4.1 翻译