Problem C

Statement
Copy Copied
Description:
William is a huge fan of planning ahead. That is why he starts his morning routine by creating a nested list of upcoming errands.

A valid nested list is any list which can be created from a list with one item "1" by applying some operations. Each operation inserts a new item into the list, on a new line, just after one of existing items $$$a_1 \,.\, a_2 \,.\, a_3 \,.\, \,\cdots\, \,.\,a_k$$$ and can be one of two types:

1. Add an item $$$a_1 \,.\, a_2 \,.\, a_3 \,.\, \cdots \,.\, a_k \,.\, 1$$$ (starting a list of a deeper level), or
2. Add an item $$$a_1 \,.\, a_2 \,.\, a_3 \,.\, \cdots \,.\, (a_k + 1)$$$ (continuing the current level).

When William decided to save a Word document with the list of his errands he accidentally hit a completely different keyboard shortcut from the "Ctrl-S" he wanted to hit. It's not known exactly what shortcut he pressed but after triggering it all items in the list were replaced by a single number: the last number originally written in the item number.

William wants you to help him restore a fitting original nested list.

Input Format:
Each test contains multiple test cases. The first line contains the number of test cases $$$t$$$ ($$$1 \le t \le 10$$$). Description of the test cases follows.

The first line of each test case contains a single integer $$$n$$$ ($$$1 \le n \le 10^3$$$), which is the number of lines in the list.

Each of the next $$$n$$$ lines contains a single integer $$$a_i$$$ ($$$1 \le a_i \le n$$$), which is what remains of William's nested list.

It is guaranteed that in each test case at least one fitting list exists.

It is guaranteed that the sum of values $$$n$$$ across all test cases does not exceed $$$10^3$$$.

Output Format:
For each test case output $$$n$$$ lines which represent a valid nested list, which could become the data provided to you by William.

If there are multiple answers, print any.

Note:
In the second example test case one example of a fitting list is:

1

1.1

1.1.1

1.1.2

1.2

1.2.1

2

2.1

2.2

This list can be produced by using the sequence of operations shown below:

1. Original list with a single item $$$1$$$.
2. Insert item $$$2$$$ by using the insertion operation of the second type after item $$$1$$$.
3. Insert item $$$1.1$$$ by using the insertion operation of the first type after item $$$1$$$.
4. Insert item $$$1.2$$$ by using the insertion operation of the second type after item $$$1.1$$$.
5. Insert item $$$1.1.1$$$ by using the insertion operation of the first type after item $$$1.1$$$.
6. Insert item $$$1.1.2$$$ by using the insertion operation of the second type after item $$$1.1.1$$$.
7. Insert item $$$1.2.1$$$ by using the insertion operation of the first type after item $$$1.2$$$.
8. Insert item $$$2.1$$$ by using the insertion operation of the first type after item $$$2$$$.
9. Insert item $$$2.2$$$ by using the insertion operation of the second type after item $$$2.1$$$.

Evaluations

Eval IDRun IDProviderModelLangSuccessTimestampPromptResponseStdoutStderrRetry
13 20260124-045845 vertex gemini-3-pro-preview go true 2026-01-24T05:14:13.503742Z View View View View Retry