#ATarc138a. [ARC138A] Larger Score

[ARC138A] Larger Score

题目描述

有一个长度为 NN 的整数序列 A=(A1,A2,,AN)A=(A_1,A_2,\cdots,A_N)。在本题中,我们将 AA 的前 KK 项的和称为分数。设输入给定的 AA 的分数为 ss

你可以任意次数地进行以下操作:

  • 选择 AA 中某两个相邻的元素,交换它们的值。

你的目标是使分数达到 s+1s+1 或更大。请判断目标是否可以实现,如果可以,请求出所需的最小操作次数。

输入格式

输入以如下格式从标准输入读入:

NN KK A1A_1 A2A_2 \cdots ANA_N

输出格式

如果无法实现目标,输出 -1。如果可以实现,输出所需的最小操作次数。

样例 1

输入

4 2
2 1 1 2

输出

2

样例 2

输入

3 1
3 2 1

输出

-1

样例 3

输入

20 13
90699850 344821203 373822335 437633059 534203117 523743511 568996900 694866636 683864672 836230375 751240939 942020833 865334948 142779837 22252499 197049878 303376519 366683358 545670804 580980054

输出

13

说明/提示

限制条件

  • 2N4×1052 \leq N \leq 4 \times 10^5
  • 1KN11 \leq K \leq N-1
  • 1Ai1091 \leq A_i \leq 10^9
  • 所有输入值均为整数

样例解释 1

首先,s=2+1=3s=2+1=3。可以通过如下操作使分数达到 44 或更大:

  • (2,1,1,2)(2,1,1,2) \to(交换 A3A_3A4A_4 的值)(2,1,2,1)\to (2,1,2,1) \to(交换 A2A_2A3A_3 的值)(2,2,1,1)\to (2,2,1,1)

用一次操作无法达成目标,因此所需的最小操作次数为 22

由 ChatGPT 4.1 翻译