#CF2179B. Blackslex and Showering

    ID: 6996 传统题 1000ms 256MiB 尝试: 2 已通过: 1 难度: 10 上传者: 标签>动态规划贪心模拟CodeforcesCodeforces Round 1071(Div3)Div3BCF2179B800

Blackslex and Showering

题目描述

在他的IMO奖牌获得者朋友花了两个小时洗澡(这样“一周内就不用再洗澡了”)之后,Blackslex 要迟到去上课了!

为了赶到教室,Blackslex 必须依次乘坐拥挤的电梯到达多个楼层。因为他是个黑客,他可以跳过最多一个楼层而不被其他人察觉。他所用的时间是每两个相邻楼层编号的差的绝对值之和。给定他可以跳过最多一个楼层,请你求出他所需的最短时间。

更正式地,给定一个长度为 nn 的整数数组 a=[a1,a2,,an]a = [a_1, a_2, \ldots, a_n],你可以选择最多一个下标 k{1,2,,n}k \in \{1, 2, \ldots, n\} 并删除 aka_k,使得下式的值最小:

i=1n2bibi+1\sum_{i=1}^{n-2} |b_i - b_{i+1}|

其中 b=[a1,,ak1,ak+1,,an]b = [a_1, \ldots, a_{k-1}, a_{k+1}, \ldots, a_n] 表示删除 aka_k 后的数组。请输出最小的总和。

输入格式

第一行包含一个整数 tt1t1041 \le t \le 10^4)——测试用例的数量。

每个测试用例的第一行包含一个整数 nn3n21053 \le n \le 2 \cdot 10^5)——数组的长度。

每个测试用例的第二行包含 nn 个整数 a1,a2,,ana_1, a_2, \ldots, a_n1ai1001 \le a_i \le 100)。

保证所有测试用例中 nn 的总和不超过 21052 \cdot 10^5

输出格式

对于每个测试用例,输出一个整数,表示所需的最短时间。

样例

3
5
4 15 1 7 9
3
2 4 8
6
11 13 17 19 23 29
11
2
12

样例说明

对于第一个测试用例,从 [4,15,1,7,9][4, 15, 1, 7, 9] 中删除下标 k=2k=2 (即 1515)是最优的。新数组为 [4,1,7,9][4, 1, 7, 9],耗时为 1111。对于第二个测试用例,最优删除的是下标 k=3k=3

由 ChatGPT 5 翻译

来源

Codeforces 2179B,英文题名 Blackslex and Showering。