CF2154B Make it Zigzag
题目描述
长度为 $m$ 的任意整数数组 $b$ 如果对于所有 $i$($1 \le i < m$)满足以下条件,则被认为是“awesome”(极棒)的:
- 如果 $i$ 是奇数,则 $b_i < b_{i+1}$。
- 如果 $i$ 是偶数,则 $b_i > b_{i+1}$。
换句话说,数组需满足如下不等式:$b_1 < b_2 > b_3 < b_4 \ldots$
给定一个长度为 $n$ 的正整数数组 $a$。你可以按照任意顺序、任意多次执行以下两种操作:
- 操作 $1$:选择一个整数 $i$($1 \le i \le n$),令 $a_i := \max(a_1, \ldots, a_i)$,即将 $a_i$ 替换为前缀最大值。
- 操作 $2$:选择一个整数 $i$($1 \le i \le n$),然后将 $a_i$ 减少 $1$。
请你求出使 $a$ 成为“awesome”数组所需执行操作 $2$ 的最少次数。注意:你不需要最小化执行操作 $1$ 的次数。
输入格式
每组测试包含多个测试用例。第一行输入测试用例的数量 $t$($1 \le t \le 10^4$)。接下来每组测试用例包含:
第一行输入一个整数 $n$($2 \le n \le 2 \times 10^5$),表示数组 $a$ 的长度。
第二行输入 $n$ 个整数 $a_1,a_2,\ldots,a_n$($1 \le a_i \le 10^9$)。
所有测试用例中 $n$ 的总和不超过 $2 \times 10^5$。
输出格式
对于每组测试用例,输出使 $a$ 成为“awesome”数组所需执行操作 $2$ 的最小次数。
说明/提示
在第一个测试用例中,数组已经是“awesome”的,无需任何操作。
在第二个测试用例中,可以按如下方式操作,使 $a$ 成为“awesome”:
- 执行一次操作 $2$,将 $a_1$ 减少 $1$:$[\color{red}3, 3, 2, 1] \rightarrow [\color{red}2, 3, 2, 1]$。
- 执行一次操作 $1$,将 $a_4$ 改为 $\max(2, 3, 2, 1) = 3$:$[2, 3, 2, \color{red}1] \rightarrow [2, 3, 2, \color{red}3]$。
$[2, 3, 2, 3]$ 是“awesome”数组,因为 $2 < 3 > 2 < 3$。可以证明,这是使得 $a$ 成为“awesome”数组所需的最少操作 $2$ 次数。
由 ChatGPT 5 翻译