QOJ.ac

QOJ

حد الوقت: 2 s حد الذاكرة: 1024 MB مجموع النقاط: 100 قابلة للهجوم ✓

#18669. 이진 검색 트리 복원하기

الإحصائيات

Chansol zbudował binarne drzewo poszukiwań (BST) składające się z $N$ węzłów, w których zapisane są liczby całkowite. Binarne drzewo poszukiwań to takie drzewo binarne, że dla każdego węzła $i$ wszystkie liczby w lewym poddrzewie węzła $i$ są mniejsze od liczby w węźle $i$, a wszystkie liczby w prawym poddrzewie węzła $i$ są większe od liczby w węźle $i$.

Chansol zapisał dla każdego $i$ głębokość $H_i$ węzła $i$ w drzewie oraz liczbę całkowitą $A_i$ znajdującą się w węźle $i$. Wszystkie $A_i$ są różne, a głębokość korzenia wynosi $1$. ($1 \le i \le N$)

Podczas podróży na ICPC World Finals Chansol zgubił drzewo. Pomóż mu odtworzyć binarne drzewo poszukiwań na podstawie wcześniej zapisanych informacji.

Wejście

Pierwszy wiersz zawiera liczbę węzłów $N$. ($1 \leq N \leq 200\,000$)

Kolejne $N$ wierszy zawiera informacje o węzłach drzewa. Dla każdego $1 \leq i \leq N$, $(i+1)$-szy wiersz zawiera liczbę całkowitą $A_i$ zapisaną w węźle $i$ oraz głębokość $H_i$ węzła $i$, oddzielone spacją. ($-2\cdot 10^9\leq A_i \leq 2\cdot 10^9$; $1 \leq H_i \leq N$) Wszystkie $A_i$ są różne.

Wyjście

Jeżeli na podstawie podanych danych nie można odtworzyć binarnego drzewa poszukiwań, wypisz $-1$.

W przeciwnym przypadku wypisz strukturę drzewa w $N$ wierszach.

W $i$-tym wierszu wypisz numery lewego i prawego dziecka węzła $i$. Jeżeli dziecko nie istnieje, wypisz $-1$ jako numer dziecka.

Jeżeli istnieje wiele możliwych drzew, możesz wypisać dowolne z nich.

Przykład

Wejście 1

3
1 2
2 1
3 2

Wyjście 1

-1 -1
1 3
-1 -1

Wejście 2

3
1 1
2 2
3 2

Wyjście 2

-1

Wejście 3

3
2 2
5 3
4 2

Wyjście 3

-1

Wejście 4

3
100 2
200 1
300 2

Wyjście 4

-1 -1
1 3
-1 -1

Discussions

About Discussions

The discussion section is only for posting: General Discussions (problem-solving strategies, alternative approaches), and Off-topic conversations.

This is NOT for reporting issues! If you want to report bugs or errors, please use the Issues section below.

Open Discussions 0
No discussions in this category.

Issues

About Issues

If you find any issues with the problem (statement, scoring, time/memory limits, test cases, etc.), you may submit an issue here. A problem moderator will review your issue.

Guidelines:

  1. This is not a place to publish discussions, editorials, or requests to debug your code. Issues are only visible to you and problem moderators.
  2. Do not submit duplicated issues.
  3. Issues must be filed in English or Chinese only.
Active Issues 0
No issues in this category.
Closed/Resolved Issues 0
No issues in this category.