#HK4770. 「ROIR 2025 Day2」不平衡的划分

「ROIR 2025 Day2」不平衡的划分

题目描述

译自 ROI Regional 2025 Day2 T2. Перекошенное разбиение

给定一个由非负整数组成的数组 [a1,a2,,an][a_1, a_2, \ldots, a_n]

考虑将该数组划分为连续的 kk 个非空子段。

我们将一个划分的不平衡度定义为这些子段中最大子段和与最小子段和的差值。

你的任务是找到将该数组划分为 kk 个子段的最大不平衡度。

例如,如果数组为 [2,1,3,4][2, 1, 3, 4]

  • 划分为 [2,1,3][4][2, 1, 3][4] 时,不平衡度为 64=26 - 4 = 2
  • 划分为 [2,1][3,4][2, 1][3, 4] 时,不平衡度为 73=47 - 3 = 4
  • 划分为 [2][1,3,4][2][1, 3, 4] 时,不平衡度为 82=68 - 2 = 6

最后一种划分是在将数组划分为两个非空子段时的不平衡度最大值。

输入格式

第一行包含两个整数 nnkk (2kn300000)(2 \leq k \leq n \leq 300\,000),分别表示数组的长度和子段的数量。

第二行包含 nn 个整数 aia_i (0ai109)(0 \leq a_i \leq 10^9),表示数组的元素。

输出格式

输出一个整数,表示将该数组划分为 kk 个子段的最大不平衡度。

4 2
2 1 3 4

6

第一个样例已在题目描述中进行了详细解释。

5 4
2 1 3 4 1

6

第二个样例中,最优的划分是 [2][1][3,4][1][2][1][3, 4][1]。在这个划分中,子段的最大和为 3+4=73 + 4 = 7,最小和为 11,因此不平衡度为 66

数据范围与提示

详细子任务附加限制及分值如下表所示。

子任务 分值 附加限制 子任务依赖
11 1111 n15n \leq 15
22 1111 k=2k = 2
33 2121 k=3k = 3
44 1515 n300n \leq 300 11
55 2121 n3000n \leq 3\,000 1, 4
66 2121 无附加限制 151\sim 5