CF1650D.Twist the Permutation

普及/提高-

通过率:0%

AC君温馨提醒

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

题目描述

Petya got an array aa of numbers from 11 to nn , where a[i]=ia[i]=i .

He performed nn operations sequentially. In the end, he received a new state of the aa array.

At the ii -th operation, Petya chose the first ii elements of the array and cyclically shifted them to the right an arbitrary number of times (elements with indexes i+1i+1 and more remain in their places). One cyclic shift to the right is such a transformation that the array a=[a1,a2,,an]a=[a_1, a_2, \dots, a_n] becomes equal to the array a=[ai,a1,a2,,ai2,ai1,ai+1,ai+2,,an]a = [a_i, a_1, a_2, \dots, a_{i-2}, a_{i-1}, a_{i+1}, a_{i+2}, \dots, a_n] .

For example, if a=[5,4,2,1,3]a = [5,4,2,1,3] and i=3i=3 (that is, this is the third operation), then as a result of this operation, he could get any of these three arrays:

  • a=[5,4,2,1,3]a = [5,4,2,1,3] (makes 00 cyclic shifts, or any number that is divisible by 33 );
  • a=[2,5,4,1,3]a = [2,5,4,1,3] (makes 11 cyclic shift, or any number that has a remainder of 11 when divided by 33 );
  • a=[4,2,5,1,3]a = [4,2,5,1,3] (makes 22 cyclic shifts, or any number that has a remainder of 22 when divided by 33 ).

Let's look at an example. Let n=6n=6 , i.e. initially a=[1,2,3,4,5,6]a=[1,2,3,4,5,6] . A possible scenario is described below.

  • i=1i=1 : no matter how many cyclic shifts Petya makes, the array aa does not change.
  • i=2i=2 : let's say Petya decided to make a 11 cyclic shift, then the array will look like a=[2,1,3,4,5,6]a = [\textbf{2}, \textbf{1}, 3, 4, 5, 6] .
  • i=3i=3 : let's say Petya decided to make 11 cyclic shift, then the array will look like a=[3,2,1,4,5,6]a = [\textbf{3}, \textbf{2}, \textbf{1}, 4, 5, 6] .
  • i=4i=4 : let's say Petya decided to make 22 cyclic shifts, the original array will look like a=[1,4,3,2,5,6]a = [\textbf{1}, \textbf{4}, \textbf{3}, \textbf{2}, 5, 6] .
  • i=5i=5 : let's say Petya decided to make 00 cyclic shifts, then the array won't change.
  • i=6i=6 : let's say Petya decided to make 44 cyclic shifts, the array will look like a=[3,2,5,6,1,4]a = [\textbf{3}, \textbf{2}, \textbf{5}, \textbf{6}, \textbf{1}, \textbf{4}] .

You are given a final array state aa after all nn operations. Determine if there is a way to perform the operation that produces this result. In this case, if an answer exists, print the numbers of cyclical shifts that occurred during each of the nn operations.

输入格式

The first line of the input contains an integer tt ( 1t5001 \le t \le 500 ) — the number of test cases in the test.

The descriptions of the test cases follow.

The first line of the description of each test case contains one integer nn ( 2n21032 \le n \le 2\cdot10^3 ) — the length of the array aa .

The next line contains the final state of the array aa : nn integers a1,a2,,ana_1, a_2, \dots, a_n ( 1ain1 \le a_i \le n ) are written. All aia_i are distinct.

It is guaranteed that the sum of nn values over all test cases does not exceed 21032\cdot10^3 .

输出格式

For each test case, print the answer on a separate line.

Print -1 if the given final value aa cannot be obtained by performing an arbitrary number of cyclic shifts on each operation. Otherwise, print nn non-negative integers d1,d2,,dnd_1, d_2, \dots, d_n ( di0d_i \ge 0 ), where did_i means that during the ii -th operation the first ii elements of the array were cyclic shifted to the right did_i times.

If there are several possible answers, print the one where the total number of shifts is minimal (that is, the sum of did_i values is the smallest). If there are several such answers, print any of them.

输入输出样例

  • 输入#1

    3
    6
    3 2 5 6 1 4
    3
    3 1 2
    8
    5 8 1 3 2 6 4 7

    输出#1

    0 1 1 2 0 4 
    0 0 1 
    0 1 2 0 2 5 6 2

说明/提示

The first test case matches the example from the statement.

The second set of input data is simple. Note that the answer [3,2,1][3, 2, 1] also gives the same permutation, but since the total number of shifts 3+2+13+2+1 is greater than 0+0+10+0+1 , this answer is not correct.

首页