CF2205D Simons and Beating Peaks

题目描述

我最美好的愿望随风消散;十八岁时,我将梦想倾注于麦克风,与你们分享。 —— SHUN,[720](https://open.spotify.com/track/3bhQrFuaaPk8pMMb7TcU2d) 我们称长度为 $m$ 的数组 $b$ 为“cool”(酷),当且仅当: - 不存在下标 $i$($1 < i < m$),使得 $b_i = \max(\{b_{i-1}, b_i, b_{i+1}\})$。 Simons 有一个大小为 $n$ 的数组 $a$。最初,该数组是一个排列$^{\text{∗}}$。 他需要持续进行如下操作,直到数组变为cool: - 选择一个下标 $i$($1 < i < n$),满足 $a_i = \max(\{a_{i-1}, a_i, a_{i+1}\})$。 - 然后,他可以从数组中删除 $a_{i-1}$ 或 $a_{i+1}$。删除后,数组的左右部分会重新拼接起来形成一个新数组。 请你求出 Simons 至少需要进行多少次操作。 $^{\text{∗}}$ 长度为 $n$ 的排列是指一个包含 $1$ 到 $n$、且每个数恰好出现一次的数组。比如 $[2,3,1,5,4]$ 是一个排列,但 $[1,2,2]$ 不是($2$ 出现了两次),$[1,3,4]$ 也不是($n=3$,但出现了 $4$)。

输入格式

每组测试数据包含多个测试用例。第一行包含测试用例个数 $t$($1 \leq t \leq 5 \cdot 10^4$)。接下来描述各组测试数据。 第一行包含一个整数 $n$($3 \leq n \leq 5 \cdot 10^5$)——$a$ 的长度。 第二行包含 $n$ 个整数 $a_1,a_2,\ldots,a_n$($1 \leq a_i \leq n$,且所有 $a_i$ 都互不相同),表示 Simons 最初拥有的数组。 保证所有测试用例中 $n$ 的总和不超过 $5 \cdot 10^5$。

输出格式

对于每个测试用例,输出一行一个整数,表示 Simons 至少需要多少次操作。

说明/提示

在第一个测试用例中,数组一开始就是 cool 的,因此 Simons 不需要任何操作。答案为 $0$。 在第二个测试用例中,Simons 可以这样操作: - 选择下标 $3$,因为 $a_3 = \max(\{a_2, a_3, a_4\})$。然后,他删除 $a_2$。数组变为 $[4,3,2,5]$。 可以发现,数组现在已经 cool。于是答案为 $1$。 在第三个测试用例中,Simons 可以这样操作: - 选择下标 $2$,然后删除 $a_1$,数组变为 $[5,3,6,2,1]$。 - 选择下标 $3$,然后删除 $a_2$,数组变为 $[5,6,2,1]$。 - 选择下标 $2$,然后删除 $a_1$,数组变为 $[6,2,1]$。 因此,Simons 一共进行了 $3$ 次操作使数组变为 cool。 由 ChatGPT 5 翻译