CF BUDDY
← Problems·

1852C · Ina of the Mountain

2400 · data structures, dp, greedy

Problem: 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.

Input Format: 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.

Output Format: 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.

Note: 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].

Sample Cases

Case 1

Input

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

Output

2
4

Similar problems

00:00:00
Loading editor…
Welcome! I'm your coding tutor for this problem. Use the chips below to reveal stored hints or get AI feedback on your code. I'll guide you step by step — never giving away the solution.

Sign in to unlock AI tutor feedback