CF2027B Stalin Sort
题目描述
Stalin Sort 是一种有趣的排序算法,旨在消除不合适的元素,而不是贪心地对它们进行正确排序,从而将自己时间复杂度变为$ \mathcal{O}(n) $。
它是这样进行的:从数组中的第二个元素开始,如果它严格小于前一个元素(忽略那些已经被删除的元素),则删除它。继续遍历数组,直到它按非降序排序。例如,数组$ [1, 4, 2, 3, 6, 5, 5, 7, 7] $经过斯大林排序后的结果是$ [1, 4, 6, 7, 7] $。
如果您可以通过对数组的任何子数组$ ^{\text{∗}} $重复应用 Stalin Sort 来使数组以非递增顺序排序,那么我们将这样的数组定义为vulnerable,根据需要可以多次调用。
给定一个含$ n $个整数的数组$ a $,确定最少需要从数组中删除几个整数,才能让这个数组变得vulnerable。
$ ^{\text{∗}} $如果数组$ a $可以通过由数组$ b $从头部和尾部删除几个(可以是零个或者所有)元素获得,那么我们认为数组$ a $是数组$ b $的子数组。
输入格式
每个测试点由多组数据组成。每个测试点的第一行包含一个整数$ t $ ( $ 1 \le t \le 500 $ ),用于表示测试数据的组数。接下来是各组数据的描述。
每组数据的第一行包含一个整数
$ n $ ( $ 1 \le n \le 2000 $ ),用于表示数组的大小。
每个数据的第二行包含$ n $个整数$ a_1, a_2, \ldots, a_n $ ( $ 1 \le a_i \le 10^9 $ )
保证$ n $在所有数据中不超过$ 2000 $.
输出格式
对于每组数据,输出一个整数,用于表示最少需要从数组中删除几个整数,才能使数组变得vulnerable。
说明/提示
在第1个输入输出样例中,最佳答案是删除数字$ 3 $和$ 9 $.然后我们只剩下$ a = [6, 4, 2, 5, 2] $.为了使这个数组变得脆弱,我们可以首先对子数组$ [4, 2, 5] $应用 Stalin Sort来获得$ a = [6, 4, 5, 2] $,然后在子数组$ [6, 4, 5] $上应用 Stalin Sort来获得非递增的数组$ a = [6, 2] $
在第2个输入输出样例中,数组已经是非递增的了,因此不必删除任何数。
题面翻译来自[映月之晴](https://www.luogu.com.cn/user/505433)