CF1987B.Sort

传统题 时间 2000 ms 内存 256 MiB 5 尝试 1 已通过 1 标签

Sort

题目描述

给定一个长度为 nn 的整数数组 aa

你可以进行如下操作任意次(可以为零次):

  • 首先,选择一个整数 kk,满足 1kn1 \le k \le n,并支付 k+1k+1 个硬币。
  • 然后,选择恰好 kk 个下标,满足 1i1<i2<<ikn1 \le i_1 < i_2 < \ldots < i_k \le n
  • 接着,对于每个 xx11kk,将 aixa_{i_x} 增加 11

请你求出使数组 aa 变为非递减(即 a1a2ana_1 \le a_2 \le \ldots \le a_n)所需的最少硬币数。

输入格式

每组测试数据包含多组测试用例。输入的第一行包含一个整数 tt1t1041 \le t \le 10^4),表示测试用例的组数。接下来是每组测试用例的描述。

每组测试用例的第一行包含一个整数 nn1n1051 \le n \le 10^5),表示数组 aa 的长度。

第二行包含 nn 个整数 a1,a2,,ana_1, a_2, \ldots, a_n1ai1091 \le a_i \le 10^9),表示数组 aa 的元素。

保证所有测试用例中 nn 的总和不超过 10510^5

输出格式

对于每组测试用例,输出一个整数,表示使 aa 变为非递减所需的最少硬币数。

说明/提示

在第一个测试用例中,aa 已经是有序的,因此你不需要花费任何硬币。

在第二个测试用例中,最优的操作序列如下:

  • 选择 k=2k=2,下标为 2255:$[2, \color{red}{1}, 4, 7, \color{red}{6}] \rightarrow [2, 2, 4, 7, 7]$。这需要花费 33 个硬币。

可以证明,无法用少于 33 个硬币使 aa 变为非递减。

由 ChatGPT 4.1 翻译

样例

5
3
1 7 9
5
2 1 4 7 6
4
1 3 2 4
1
179
9
344 12 37 60 311 613 365 328 675
0
3
2
0
1821

在线编程 IDE

建议全屏模式获得最佳体验