Permutation recovery

题意翻译

有一个排列 $p$,定义 $nxt_i$ 为 $p_i$ 右侧第一个大于 $p_i$ 的位置。若不存在这样的位置则 $nxt_i=n+1$。 现在排列 $p$ 和部分 $nxt_i$ 丢失了。你需要构造出一个排列 $p$,满足给出的 $nxt_i$ 关系。$nxt_i=-1$ 表示 $nxt_i$ 丢失(即你可以忽略这个 $nxt_i$ 关系)。 若无解,输出 `-1`。若有多组解,输出任意一组即可。

题目描述

Vasya has written some permutation $ p_1, p_2, \ldots, p_n $ of integers from $ 1 $ to $ n $ , so for all $ 1 \leq i \leq n $ it is true that $ 1 \leq p_i \leq n $ and all $ p_1, p_2, \ldots, p_n $ are different. After that he wrote $ n $ numbers $ next_1, next_2, \ldots, next_n $ . The number $ next_i $ is equal to the minimal index $ i < j \leq n $ , such that $ p_j > p_i $ . If there is no such $ j $ let's let's define as $ next_i = n + 1 $ . In the evening Vasya went home from school and due to rain, his notebook got wet. Now it is impossible to read some written numbers. Permutation and some values $ next_i $ are completely lost! If for some $ i $ the value $ next_i $ is lost, let's say that $ next_i = -1 $ . You are given numbers $ next_1, next_2, \ldots, next_n $ (maybe some of them are equal to $ -1 $ ). Help Vasya to find such permutation $ p_1, p_2, \ldots, p_n $ of integers from $ 1 $ to $ n $ , that he can write it to the notebook and all numbers $ next_i $ , which are not equal to $ -1 $ , will be correct.

输入输出格式

输入格式


The first line contains one integer $ t $ — the number of test cases ( $ 1 \leq t \leq 100\,000 $ ). Next $ 2 \cdot t $ lines contains the description of test cases,two lines for each. The first line contains one integer $ n $ — the length of the permutation, written by Vasya ( $ 1 \leq n \leq 500\,000 $ ). The second line contains $ n $ integers $ next_1, next_2, \ldots, next_n $ , separated by spaces ( $ next_i = -1 $ or $ i < next_i \leq n + 1 $ ). It is guaranteed, that the sum of $ n $ in all test cases doesn't exceed $ 500\,000 $ . In hacks you can only use one test case, so $ T = 1 $ .

输出格式


Print $ T $ lines, in $ i $ -th of them answer to the $ i $ -th test case. If there is no such permutations $ p_1, p_2, \ldots, p_n $ of integers from $ 1 $ to $ n $ , that Vasya could write, print the only number $ -1 $ . In the other case print $ n $ different integers $ p_1, p_2, \ldots, p_n $ , separated by spaces ( $ 1 \leq p_i \leq n $ ). All defined values of $ next_i $ which are not equal to $ -1 $ should be computed correctly $ p_1, p_2, \ldots, p_n $ using defenition given in the statement of the problem. If there exists more than one solution you can find any of them.

输入输出样例

输入样例 #1

6
3
2 3 4
2
3 3
3
-1 -1 -1
3
3 4 -1
1
2
4
4 -1 4 5

输出样例 #1

1 2 3
2 1
2 1 3
-1
1
3 2 1 4

说明

In the first test case for permutation $ p = [1, 2, 3] $ Vasya should write $ next = [2, 3, 4] $ , because each number in permutation is less than next. It's easy to see, that it is the only satisfying permutation. In the third test case, any permutation can be the answer because all numbers $ next_i $ are lost. In the fourth test case, there is no satisfying permutation, so the answer is $ -1 $ .