P9483 [NOI2023] 合并书本

题目描述

小 C 有 $n$ 本书,每本书都有一个重量,他决定把它们合并成一摞。 每一次合并小 C 可以把一摞书放到另一摞书上面,使得它们合并到一摞。如果小 C 把第 $i$ 摞书放到第 $j$ 摞书上面,小 C 需要消耗的体力为**第 $i$ 摞书的重量**加上**两摞书的磨损值之和**。 初始时每本书自成一摞且磨损值均为 $0$。每当小 C 将两摞书合并后,形成的新的一摞书的磨损值为合并前的两摞书的磨损值的**较大值的两倍再加一**,重量为合并前的两摞书的**重量之和**。 你的任务是设计出合并的次序方案,使小 C 耗费的体力最少,并输出这个最小的体力耗费值。

输入格式

**本题有多组测试数据。** 输入的第一行包含一个正整数 $t$,表示数据组数。 接下来依次输入每组测试数据,对于每组测试数据: 输入的第一行包含一个正整数 $n$,表示有 $n$ 本书。 输入的第二行包含 $n$ 个正整数,第 $i$ 个数 $w_i$ 表示第 $i$ 本书的重量。

输出格式

对于每组测试数据输出一行一个整数,表示将 $n$ 本书合并成一摞需要消耗的最少体力。

说明/提示

**【样例解释 #1】** 如果小 C 将 $4$ 本书两两合并再将得到的两摞合并成一摞,那么前两次需要消耗的体力值各为 $1$。第三次将一摞重量为 $2$ 的书放到另一摞上面,两摞书磨损值各为 $1$,需要消耗的体力为 $2 + 1 + 1 = 4$。 因此如果选择这个方案,小 C 耗费的体力只有 $1 + 1 + 4 = 6$。 可以证明,在上述例子中,$6$ 为最小的体力耗费值。 **【数据范围】** 对于所有测试数据保证:$1 \le t \le 10$,$1 \le n \le 100$,$1 \le w_i \le 10 ^ 9$。 |测试点编号|$n \le$|是否有特殊性质| |:-:|:-:|:-:| |$1 \sim 2$|$7$|否| |$3$|$11$|否| |$4$|$13$|否| |$5 \sim 6$|$22$|否| |$7 \sim 8$|$28$|否| |$9 \sim 13$|$50$|否| |$14$|$60$|否| |$15$|$70$|否| |$16$|$80$|否| |$17 \sim 18$|$100$|是| |$19 \sim 20$|$100$|否| 特殊性质:保证 $w_i = 1$。