În acest weekend tocmai s-au pus în vânzare bilete pentru concertul celui mai în vogă artist. Cum acesta este extrem de popular, un număr de persoane s-au așezat la coadă la casa de bilete. Pentru simplitate, prima persoană așezată la coadă va avea indicele , a doua va avea indicele și așa mai departe.
Deoarece statul la coadă este extrem de plictisitor, fiecare om a început să numere câte persoane mai scunde decât el se află în fața sa. Se cunoaște că înălțimile oamenilor sunt reprezentate cu numere naturale nenule.
Din lipsă de imaginație, oamenii care stau la coadă nu au reușit sa ducă jocul până la capăt, așa că o vom face noi. Cunoscând câte persoane mai scunde decât el are în față fiecare om care stă la coadă, se cere să se determine înălțimea fiecărui om din șir.
Dacă există mai multe soluții valide, se cere afișată soluția minim lexicografică. Dacă există două șiruri valide de înălțimi ale celor persoane și spunem că șirul este mai mic lexicografic decât dacă există un număr natural mai mic sau egal cu , astfel încât și , oricare ar fi .
Cerință
Fiind dat șirul inițial de observații ale oamenilor care stau la coadă, să se reconstruiască șirul minim lexicografic care poate reprezenta înălțimile acestora.
Date de intrare
În fișierul weekend.in
se va afla pe prima linie numărul . Pe linia a doua se va afla un șir de numere naturale despărțite printr-un spațiu, valoarea aflată pe poziția semnificând numărul de persoane strict mai scunde decât persoana și cu indice mai mic decât .
Date de ieșire
În fișierul weekend.out
se va afișa șirul înălțimilor. Pe linia a i
-a din fișierul de ieșire se va afla înălțimea persoanei cu indicele i
.
Restricții și precizări
- Se garantează că setul de date este corect și va exista mereu cel puțin o soluție;
- Două sau mai multe persoane NU pot avea aceeași înălțime;
- ;
- Pentru 40% din teste: .
Exemplu
weekend.in
4
0 1 1 0
weekend.out
2
4
3
1
Explicație
Observăm că acesta este cel mai mic șir lexicografic care satisface șirul de observații din input.
O altă soluție ar fi fost șirul 2 5 3 1
, dar acesta este mai mare lexicografic.