← Home
write a go solution for Description:
You are given an array a consisting of n integers.

In one move, you can choose some index i (1<=i<=n-2) and shift the segment [a_i,a_i+1,a_i+2] cyclically to the right (i.e. replace the segment [a_i,a_i+1,a_i+2] with [a_i+2,a_i,a_i+1]).

Your task is to sort the initial array by no more than n^2 such operations or say that it is impossible to do that.

You have to answer t independent test cases.

Input Format:
The first line of the input contains one integer t (1<=t<=100) — the number of test cases. Then t test cases follow.

The first line of the test case contains one integer n (3<=n<=500) — the length of a. The second line of the test case contains n integers a_1,a_2,...,a_n (1<=a_i<=500), where a_i is the i-th element a.

It is guaranteed that the sum of n does not exceed 500.

Output Format:
For each test case, print the answer: -1 on the only line if it is impossible to sort the given array using operations described in the problem statement, or the number of operations ans on the first line and ans integers idx_1,idx_2,...,idx_ans (1<=idx_i<=n-2), where idx_i is the index of left border of the segment for the i-th operation. You should print indices in order of performing operations.

Note:
None. Output only the code with no comments, explanation, or additional text.