Logo
(追記) (追記ここまで)

27476번 - Suffix Operations 다국어

시간 제한메모리 제한제출정답맞힌 사람정답 비율
1 초 (추가 시간 없음) 512 MB67545080.645%

문제

Gildong has an interesting machine that has an array $a$ with $n$ integers. The machine supports two kinds of operations:

  1. Increase all elements of a suffix of the array by 1ドル$.
  2. Decrease all elements of a suffix of the array by 1ドル$.

A suffix is a subsegment (contiguous elements) of the array that contains $a_n$. In other words, for all $i$ where $a_i$ is included in the subsegment, all $a_j$’s where $i\lt j\le n$ must also be included in the subsegment.

Gildong wants to make all elements of $a$ 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 $t$ (1ドル\le t\le 1000$).

Each test case contains two lines. The first line of each test case consists of an integer $n$ (2ドル\le n\le 2\cdot 10^5$) --- the number of elements of the array $a$.

The second line of each test case contains $n$ integers. The $i$-th integer is $a_i$ ($-5\cdot 10^8\le a_i\le 5\cdot 10^8$).

It is guaranteed that the sum of $n$ in all test cases does not exceed 2ドル\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 $a_3$ to be 0ドル,ドル so that the array becomes $[-1,0,0]$. Now Gildong can use the 2ドル$-nd operation once on the suffix starting at $a_2,ドル which means $a_2$ and $a_3$ are decreased by 1ドル,ドル making all elements of the array $-1$.

In the third case, we can set $a_1$ to 96ドル,ドル so that the array becomes $[96,96,97,95]$. Now Gildong needs to:

  • Use the 2ドル$-nd operation on the suffix starting at $a_3$ once, making the array $[96,96,96,94]$.
  • Use the 1ドル$-st operation on the suffix starting at $a_4$ 2ドル$ times, making the array $[96,96,96,96]$.

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

  • Use the 2ドル$-nd operation on the suffix starting at $a_4$ 3ドル$ times, making the array $[-3,-3,-2,-2]$.
  • Use the 2ドル$-nd operation on the suffix starting at $a_3$ once, making the array $[-3,-3,-3,-3]$.

출처

Contest > Codeforces > Codeforces Round 688 (Div. 2) B번

(追記) (追記ここまで)

출처

대학교 대회

  • 사업자 등록 번호: 541-88-00682
  • 대표자명: 최백준
  • 주소: 서울시 서초구 서초대로74길 29 서초파라곤 412호
  • 전화번호: 02-521-0487 (이메일로 연락 주세요)
  • 이메일: contacts@startlink.io
  • 통신판매신고번호: 제 2017-서울서초-2193 호

AltStyle によって変換されたページ (->オリジナル) /