CF1852C.Ina of the Mountain

普及/提高-

通过率:0%

AC君温馨提醒

该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。

题目描述

To prepare her "Takodachi" dumbo octopuses for world domination, Ninomae Ina'nis, a.k.a. Ina of the Mountain, orders Hoshimachi Suisei to throw boulders at them. Ina asks you, Kiryu Coco, to help choose where the boulders are thrown.

There are nn octopuses on a single-file trail on Ina's mountain, numbered 1,2,,n1, 2, \ldots, n . The ii -th octopus has a certain initial health value aia_i , where 1aik1 \leq a_i \leq k .

Each boulder crushes consecutive octopuses with indexes l,l+1,,rl, l+1, \ldots, r , where 1lrn1 \leq l \leq r \leq n . You can choose the numbers ll and rr arbitrarily for each boulder.

For each boulder, the health value of each octopus the boulder crushes is reduced by 11 . However, as octopuses are immortal, once they reach a health value of 00 , they will immediately regenerate to a health value of kk .

Given the octopuses' initial health values, find the minimum number of boulders that need to be thrown to make the health of all octopuses equal to kk .

输入格式

Each test contains multiple test cases. The first line contains the number of test cases tt ( 1t1051 \le t \le 10^5 ). The description of the test cases follows.

The first line of each test case contains two integers nn and kk ( 1n21051 \le n \le 2 \cdot 10^5 , 1k1091 \le k \le 10^9 ) – the number of octopuses, and the upper bound of a octopus's health value.

The second line contains nn integers a1,a2,,ana_1, a_2, \ldots, a_n ( 1aik1 \le a_i \le k ) – the initial health values of the octopuses.

It is guaranteed that the sum of nn over all test cases does not exceed 21052 \cdot 10^5 .

输出格式

For each test case, output the minimum number of boulders that need to be thrown to make the health values of all octopuses equal to kk .

输入输出样例

  • 输入#1

    2
    4 3
    1 2 1 3
    7 3
    1 2 3 1 3 2 1

    输出#1

    2
    4

说明/提示

In the first test case, the minimum number of boulders thrown is 22 :

  • Throw the first boulder between [l,r]=[1,3][l,r] = [1,3] . Then, the octopuses' health values become [3,1,3,3][3, 1, 3, 3] .
  • Throw the second boulder between [l,r]=[2,2][l,r] = [2,2] . Then, the octopuses' health values become [3,3,3,3][3, 3, 3, 3] .

In the second test case, the minimum number of boulders thrown is 44 . The [l,r][l,r] ranges are [1,7],[2,6],[3,5],[4,4][1,7], [2, 6], [3, 5], [4, 4] .

首页