Codeforces Global Round 22 |
---|
Закончено |
Дана перестановка $$$a_1, a_2, \dots, a_n$$$ целых чисел от $$$1$$$ до $$$n$$$, и пороговое значение $$$k$$$ такое, что $$$0 \leq k \leq n$$$, по ним вычисляется последовательность $$$b_1, b_2, \dots, b_n$$$ следующим образом.
Для всех $$$1 \leq i \leq n$$$ в порядке возрастания положим $$$x = a_i$$$.
К сожалению, после построения последовательности $$$b_1, b_2, \dots, b_n$$$, перестановка $$$a_1, a_2, \dots, a_n$$$ и пороговое значение $$$k$$$ потерялись.
Теперь у вас есть только последовательность $$$b_1, b_2, \dots, b_n$$$. Ваша задача найти любую подходящую перестановку $$$a_1, a_2, \dots, a_n$$$ и пороговое значение $$$k$$$ которые порождают последовательность $$$b_1, b_2, \dots, b_n$$$. Гарантируется, что существует хотя бы одна пара перестановки $$$a_1, a_2, \dots, a_n$$$ и порогового значения $$$k$$$, что порождают $$$b_1, b_2, \dots, b_n$$$.
Перестановкой чисел от $$$1$$$ до $$$n$$$ называется последовательность длины $$$n$$$ которая содержит все целые числа от $$$1$$$ до $$$n$$$ ровно один раз.
В первой строке задано одно целое число $$$t$$$ ($$$1 \leq t \leq 10^5$$$) — количество наборов входных данных. Затем следуют описания наборов входных данных.
В первой строке набора входных данных содержится целое число $$$n$$$ ($$$1 \leq n \leq 10^5$$$), означающее длину перестановки $$$a$$$.
Во второй строке содержится $$$n$$$ целых чисел $$$b_1, b_2, \dots, b_n$$$ ($$$0 \leq b_i \leq n+1$$$), означающие элементы последовательности $$$b$$$.
Гарантируется, что существует хотя бы одна пара перестановки $$$a_1, a_2, \dots, a_n$$$ и порогового значения $$$k$$$, что порождают $$$b_1, b_2, \dots, b_n$$$.
Гарантируется, что сумма $$$n$$$ по всем наборам входных данных не превосходит $$$10^5$$$.
Для каждого набора входных данных выведите пороговое значение $$$k$$$ ($$$0 \leq k \leq n$$$) в первой строке, и затем выведите перестановку $$$a_1, a_2, \dots, a_n$$$ ($$$1 \leq a_i \leq n$$$) во второй строке так, что перестановку $$$a_1, a_2, \dots, a_n$$$ и пороговое значение $$$k$$$ порождают последовательность $$$b_1, b_2, \dots, b_n$$$. Если существуют несколько решений, выведите любое из них.
345 3 1 267 7 7 3 3 364 4 4 0 0 0
2 1 3 2 4 3 1 2 3 4 5 6 3 6 5 4 3 2 1
В первом примере перестановка $$$a = [1,3,2,4]$$$ и пороговое значение $$$k = 2$$$ породят $$$b$$$ следующим образом.
Для второго примера перестановка $$$a = [1,2,3,4,5,6]$$$ и пороговое значение $$$k = 3$$$ породят $$$b$$$ следующим образом.
Для третьего примера перестановка $$$a = [6,5,4,3,2,1]$$$ и пороговое значение $$$k = 3$$$ породят $$$b$$$ следующим образом.
Название |
---|