CF1523C.Compression and Expansion

普及/提高-

通过率:0%

AC君温馨提醒

该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。

题目描述

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 a1.a2.a3..aka_1 \,.\, a_2 \,.\, a_3 \,.\, \,\cdots\, \,.\,a_k and can be one of two types:

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

Operation can only be applied if the list does not contain two identical items afterwards. And also, if we consider every item as a sequence of numbers, then the sequence of items should always remain increasing in lexicographical order. Examples of valid and invalid lists that are shown in the picture can found in the "Notes" section.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.

输入格式

Each test contains multiple test cases. The first line contains the number of test cases tt ( 1t101 \le t \le 10 ). Description of the test cases follows.

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

Each of the next nn lines contains a single integer aia_i ( 1ain1 \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 nn across all test cases does not exceed 10310^3 .

输出格式

For each test case output nn lines which represent a valid nested list, which could become the data provided to you by William.

If there are multiple answers, print any.

输入输出样例

  • 输入#1

    2
    4
    1
    1
    2
    3
    9
    1
    1
    1
    2
    2
    1
    2
    1
    2

    输出#1

    1
    1.1
    1.2
    1.3
    1
    1.1
    1.1.1
    1.1.2
    1.2
    1.2.1
    2
    2.1
    2.2

说明/提示

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 11 .
  2. Insert item 22 by using the insertion operation of the second type after item 11 .
  3. Insert item 1.11.1 by using the insertion operation of the first type after item 11 .
  4. Insert item 1.21.2 by using the insertion operation of the second type after item 1.11.1 .
  5. Insert item 1.1.11.1.1 by using the insertion operation of the first type after item 1.11.1 .
  6. Insert item 1.1.21.1.2 by using the insertion operation of the second type after item 1.1.11.1.1 .
  7. Insert item 1.2.11.2.1 by using the insertion operation of the first type after item 1.21.2 .
  8. Insert item 2.12.1 by using the insertion operation of the first type after item 22 .
  9. Insert item 2.22.2 by using the insertion operation of the second type after item 2.12.1 .
首页