#CF2038B. 使它们相等

使它们相等

B. 使它们相等

每个测试的时间限制:2 秒
内存限制:512 兆字节

你被给定一个大小为 nn 的整数数组 aa。数组元素从 11nn 编号。

你可以执行以下操作任意多次(可能为零次):选择一个下标 ii1in1 \le i \le n);将 aia_i 减少 22,并将 a(imodn)+1a_{(i \bmod n)+1} 增加 11

执行完操作后,数组的所有元素应为非负且相等的整数。

你的任务是计算必须执行的最少操作次数。

输入

第一行包含一个整数 tt1t1041 \le t \le 10^4)——测试用例的数量。

每个测试用例的第一行包含一个整数 nn2n21052 \le n \le 2 \cdot 10^5)。

每个测试用例的第二行包含 nn 个整数 a1,a2,,ana_1, a_2, \dots, a_n1ai1091 \le a_i \le 10^9)。

输入附加限制:所有测试用例的 nn 之和不超过 21052 \cdot 10^5

输出

对于每个测试用例,输出一个整数——所需的最少操作次数。如果无法使数组所有元素相等,则输出 1-1

示例

输入:

3
2
1 1
3
1 3 2
4
2 1 2 6

输出:

0
-1
3