[HUSTFC 2023] 逆 KMP

题目描述

Walk Alone 是一个字符串大师,但是他已经对传统的字符串算法感到无聊,如 KMP 算法,所以他最近在思考逆向的 KMP。下面是他提出的问题: 给你一个长度为 $n$ 的整数序列 $a$,对于任意的整数 $i\ (1\le i\le n)$,满足 $0\le a_i<i$。你需要构造另一个整数序列 $s$,满足以下条件: - 序列 $s$ 的长度为 $n$,并且其中任意元素 $s_i$ 满足 $1\le s_i\le n$; - 对于所有的整数 $i\ (1\le i\le n)$ 和 $j\ (1\le j\le a_i)$,满足 $s_{j}=s_{i-a_i+j}$; - 满足上述条件的前提下,序列 $s$ 中出现的不同元素的数量**最多**。 当然,Walk Alone 可以很轻松地解决这道题,但他想把这道题当作对你的考验。

输入输出格式

输入格式


第一行包含一个整数 $n\ (1\le n\le 2\cdot 10^5)$,表示序列 $a$ 的长度。 第二行包含 $n$ 个整数,其中第 $i$ 个整数定义为 $a_i\ (0\le a_i<i)$。

输出格式


输出用空格间隔的 $n$ 个整数,其中第 $i$ 个整数定义为 $s_i$。如果存在多个合法答案,请输出字典序最小的那个。

输入输出样例

输入样例 #1

5
0 0 1 2 3

输出样例 #1

1 2 1 2 1 

输入样例 #2

11
0 0 0 0 2 1 0 0 3 0 1

输出样例 #2

1 2 3 1 2 1 1 2 3 4 1