CF2104B.Move to the End

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

Move to the End

题目描述

给定一个由 nn 个整数组成的数组 aa

对于从 11nn 的每个整数 kk,你需要执行以下操作:

  1. 选择数组 aa 中的任意一个元素并将其移动到数组的最右端(可以选择最后一个元素,此时数组不会改变);
  2. 输出数组 aa 最后 kk 个元素的和;
  3. 将第一步选择的元素移回其原始位置(恢复原始数组 aa)。

对于每个 kk,你需要选择移动的元素,使得输出的值尽可能大。

请计算每个 kk 对应的输出值。

输入格式

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

每个测试用例包含两行:

  • 第一行包含一个整数 nn1n21051 \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

输出格式

对于每个测试用例,输出 nn 个整数。其中第 ii 个整数表示当 k=ik=i 时能够输出的最大值。

说明/提示

以题目描述中的第一个测试用例为例:

  • k=1k=1 时,可以选择将第 66 个元素移动到末尾,数组变为 [13,5,10,14,8,13,15][13, 5, 10, 14, 8, 13, 15],输出值为 1515
  • k=2k=2 时,可以选择将第 66 个元素移动到末尾,数组变为 [13,5,10,14,8,13,15][13, 5, 10, 14, 8, 13, 15],输出值为 13+15=2813 + 15 = 28
  • k=3k=3 时,可以选择将第 44 个元素移动到末尾,数组变为 [13,5,10,8,15,13,14][13, 5, 10, 8, 15, 13, 14],输出值为 15+13+14=4215 + 13 + 14 = 42
  • k=4k=4 时,可以选择将第 55 个元素移动到末尾,数组变为 [13,5,10,14,15,13,8][13, 5, 10, 14, 15, 13, 8],输出值为 14+15+13+8=5014 + 15 + 13 + 8 = 50
  • k=5k=5 时,可以选择将第 11 个元素移动到末尾,数组变为 [5,10,14,8,15,13,13][5, 10, 14, 8, 15, 13, 13],输出值为 14+8+15+13+13=6314 + 8 + 15 + 13 + 13 = 63
  • k=6k=6 时,可以选择将第 11 个元素移动到末尾,数组变为 [5,10,14,8,15,13,13][5, 10, 14, 8, 15, 13, 13],输出值为 10+14+8+15+13+13=7310 + 14 + 8 + 15 + 13 + 13 = 73
  • k=7k=7 时,可以选择将第 66 个元素移动到末尾,数组变为 [13,5,10,14,8,13,15][13, 5, 10, 14, 8, 13, 15],输出值为 13+5+10+14+8+13+15=7813 + 5 + 10 + 14 + 8 + 13 + 15 = 78

翻译由 DeepSeek V3 完成

样例

4
7
13 5 10 14 8 15 13
6
1000000000 1000000000 1000000000 1000000000 1000000000 1000000000
1
42
2
7 5
15 28 42 50 63 73 78 
1000000000 2000000000 3000000000 4000000000 5000000000 6000000000 
42 
7 12 

在线编程 IDE

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