CF1453B.Suffix Operations

普及/提高-

通过率:0%

AC君温馨提醒

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

题目描述

Gildong has an interesting machine that has an array aa with nn integers. The machine supports two kinds of operations:

  1. Increase all elements of a suffix of the array by 11 .
  2. Decrease all elements of a suffix of the array by 11 .

A suffix is a subsegment (contiguous elements) of the array that contains ana_n . In other words, for all ii where aia_i is included in the subsegment, all aja_j 's where i<jni \lt j \le n must also be included in the subsegment.

Gildong wants to make all elements of aa equal — he will always do so using the minimum number of operations necessary. To make his life even easier, before Gildong starts using the machine, you have the option of changing one of the integers in the array to any other integer. You are allowed to leave the array unchanged. You want to minimize the number of operations Gildong performs. With your help, what is the minimum number of operations Gildong will perform?

Note that even if you change one of the integers in the array, you should not count that as one of the operations because Gildong did not perform it.

输入格式

Each test contains one or more test cases. The first line contains the number of test cases tt ( 1t10001 \le t \le 1000 ).

Each test case contains two lines. The first line of each test case consists of an integer nn ( 2n21052 \le n \le 2 \cdot 10^5 ) — the number of elements of the array aa .

The second line of each test case contains nn integers. The ii -th integer is aia_i ( 5108ai5108-5 \cdot 10^8 \le a_i \le 5 \cdot 10^8 ).

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

输出格式

For each test case, print one integer — the minimum number of operations Gildong has to perform in order to make all elements of the array equal.

输入输出样例

  • 输入#1

    7
    2
    1 1
    3
    -1 0 2
    4
    99 96 97 95
    4
    -3 -5 -2 1
    6
    1 4 3 2 4 1
    5
    5 0 0 0 5
    9
    -367741579 319422997 -415264583 -125558838 -300860379 420848004 294512916 -383235489 425814447

    输出#1

    0
    1
    3
    4
    6
    5
    2847372102

说明/提示

In the first case, all elements of the array are already equal. Therefore, we do not change any integer and Gildong will perform zero operations.

In the second case, we can set a3a_3 to be 00 , so that the array becomes [1,0,0][-1,0,0] . Now Gildong can use the 22 -nd operation once on the suffix starting at a2a_2 , which means a2a_2 and a3a_3 are decreased by 11 , making all elements of the array 1-1 .

In the third case, we can set a1a_1 to 9696 , so that the array becomes [96,96,97,95][96,96,97,95] . Now Gildong needs to:

  • Use the 22 -nd operation on the suffix starting at a3a_3 once, making the array [96,96,96,94][96,96,96,94] .
  • Use the 11 -st operation on the suffix starting at a4a_4 22 times, making the array [96,96,96,96][96,96,96,96] .

In the fourth case, we can change the array into [3,3,2,1][-3,-3,-2,1] . Now Gildong needs to:

  • Use the 22 -nd operation on the suffix starting at a4a_4 33 times, making the array [3,3,2,2][-3,-3,-2,-2] .
  • Use the 22 -nd operation on the suffix starting at a3a_3 once, making the array [3,3,3,3][-3,-3,-3,-3] .
首页