시간 제한메모리 제한제출정답맞힌 사람정답 비율
1 초 1024 MB20314611671.166%

문제

김소마는 최근에 포화 이진 트리에 대해 배웠다. 포화 이진 트리란, 이진 트리에서 리프 노드를 제외한 모든 노드가 두 자식 노드를 가지며, 모든 리프 노드가 채워진 것을 말한다. 아래의 그림을 통해 쉽게 이해하자.

김소마는 예쁜 포화 이진 검색 트리를 그려 만족했지만, 밥 먹다 흘린 소스가 리프 노드 한 개를 가려버렸다. 여기서 이진 검색 트리란, 모든 왼쪽 자식이 자신보다 작고, 모든 오른쪽 자식이 자신보다 큰 이진 트리를 이야기한다.

그림을 버리려던 찰나, 김소마는 갑자기 포화 이진 검색 트리를 유지하며, 임의의 수를 넣을 때, 트리 구조가 어떻게 바뀔지 궁금해졌다. 멍청한 김소마를 위해 당신이 도와주자.

입력

첫 번째 줄에 가려진 노드를 포함한 노드의 개수 $N$이 주어진다. $(N=2^k-1;$ $2 \le k \le 17;$ $k$는 정수$)$

두 번째 줄에 $A_1, A_2, \cdots, A_N$이 공백으로 구분되어 주어진다. $A_i$는 $i$번 노드에 적혀있는 수이다. $(0 \le A_i \le 10^9;$ 가려진 하나의 노드에 대해서만 $A_i = -1)$ $i \neq j$이면 $A_i \neq A_j$이다. 노드 번호는 루트 노드부터 시작하여, 같은 깊이 내 왼쪽에서 오른쪽으로 갈수록 증가하는 순서로 매겨진다 (아래 그림 참조).

세 번째 줄에 트리에 넣을 수 $X$가 주어진다. $(0 \le X \le 10^9;$ $X \neq A_i)$

입력으로 주어지는 모든 수는 정수이다.

출력

첫 번째 줄에 바뀐 트리를 후위(postorder) 순회한 결과를 출력한다. (단, 왼쪽 자식 노드를 먼저 방문한다.)

예제 입력 1

7
10 5 17 1 -1 14 21
18

예제 출력 1

1 10 5 17 21 18 14

출처

Contest > SW마에스트로 > 제13기 알고리즘 대회 D번