F. Shift and Reverse
time limit per test
2.0 s
memory limit per test
256 megabytes
input
standard input
output
standard output

Given an array of integers $a_1, a_2, \ldots, a_n$. You can make two types of operations with this array:

• Shift: move the last element of array to the first place, and shift all other elements to the right, so you get the array $a_n, a_1, a_2, \ldots, a_{n-1}$.
• Reverse: reverse the whole array, so you get the array $a_n, a_{n-1}, \ldots, a_1$.

Your task is to sort the array in non-decreasing order using the minimal number of operations, or say that it is impossible.

Input

The first line of input contains a single integer $t$ ($1 \le t \le 10^4$) — the number of test cases. Descriptions of test cases follow.

The first line of each test case contains an integer $n$ ($1\le n \le 10^5$) — size of the array.

The second line of each test case contains $n$ integers $a_1, a_2, \ldots, a_n$ ($1 \le a_i \le 10^9$) — elements of the array.

It is guaranteed that sum of $n$ over all test cases does not exceed $2 \cdot 10^5$.

Output

For each test case output the number $k$, the minimal number of operations you need to sort the array. If it is impossible to sort the array using these operations, output $-1$.

Example
Input
1153 2 1 5 451 1 2 1 143 7 10 551 2 3 4 525 133 4 154 1 3 4 435 1 142 5 5 452 2 1 1 225 5
Output
3
2
-1
0
1
1
3
1
2
2
0

Note

In the first test case of the example, to sort the array [$3, 2, 1, 5, 4$] you need to perform $3$ operations:

• Shift to obtain the array [$4, 3, 2, 1, 5$];
• Shift to obtain the array [$5, 4, 3, 2, 1$];
• Reverse to obtain the array [$1, 2, 3, 4, 5$].

In the third test case of the example, it can be shown that it is impossible to sort the array using the given operations.

In the seventh test case of the example, to sort the array [$4, 1, 3, 4, 4$] you need to perform $3$ operations:

• Reverse to obtain the array [$4, 4, 3, 1, 4$];
• Shift to obtain the array [$4, 4, 4, 3, 1$];
• Reverse to obtain the array [$1, 3, 4, 4, 4$].