#P9562. [SDCPC 2023] Matching

[SDCPC 2023] Matching

Description

给定长度为 nn 的整数序列 a1,a2,,ana_1, a_2, \cdots, a_n,我们将从该序列中构造出一张无向图 GG。具体来说,对于所有 1i<jn1 \le i < j \le n,若 ij=aiaji - j = a_i - a_j,则 GG 中将存在一条连接节点 iijj 的无向边,其边权为 (ai+aj)(a_i + a_j)

GG 的一个匹配,使得该匹配中所有边的边权之和最大,并输出最大边权之和。

请回忆:无向图的匹配,指的是从该无向图中选出一些边,使得任意两条边都没有公共的节点。特别地,不选任何边也是一个匹配。

Input Format

有多组测试数据。第一行输入一个整数 TT 表示测试数据组数。对于每组测试数据:

第一行输入一个整数 nn2n1052 \le n \le 10^5)表示序列的长度。

第二行输入 nn 个整数 a1,a2,,ana_1, a_2, \cdots, a_n109ai109-10^9 \le a_i \le 10^9)表示序列。

保证所有数据中 nn 之和不超过 5×1055 \times 10^5

Output Format

每组数据输出一行一个整数,表示匹配的最大边权之和。

【样例解释】

对于第一组样例数据,最优方案是选择连接节点 3355,节点 4477,以及节点 8899 的三条边,边权之和为 (5+7)+(6+9)+(1+2)=30(5 + 7) + (6 + 9) + (1 + 2) = 30

对于第二组样例数据,由于每条边的边权都是负数,因此最优匹配不应该选择任何边,答案为 00

对于第三组样例数据,由于图中不存在任何边,因此答案为 00

3
9
3 -5 5 6 7 -1 9 1 2
3
-5 -4 -3
3
1 10 100

30
0
0