CF1919C.Grouping Increases

普及/提高-

通过率:0%

AC君温馨提醒

该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。

题目描述

You are given an array aa of size nn . You will do the following process to calculate your penalty:

  1. Split array aa into two (possibly empty) subsequences ^\dagger ss and tt such that every element of aa is either in ss or tt^\ddagger .
  2. For an array bb of size mm , define the penalty p(b)p(b) of an array bb as the number of indices ii between 11 and m1m - 1 where bi<bi+1b_i < b_{i + 1} .
  3. The total penalty you will receive is p(s)+p(t)p(s) + p(t) .

If you perform the above process optimally, find the minimum possible penalty you will receive.

^\dagger A sequence xx is a subsequence of a sequence yy if xx can be obtained from yy by the deletion of several (possibly, zero or all) elements.

^\ddagger Some valid ways to split array a=[3,1,4,1,5]a=[3,1,4,1,5] into (s,t)(s,t) are ([3,4,1,5],[1])([3,4,1,5],[1]) , ([1,1],[3,4,5])([1,1],[3,4,5]) and ([],[3,1,4,1,5])([\,],[3,1,4,1,5]) while some invalid ways to split aa are ([3,4,5],[1])([3,4,5],[1]) , ([3,1,4,1],[1,5])([3,1,4,1],[1,5]) and ([1,3,4],[5,1])([1,3,4],[5,1]) .

输入格式

Each test contains multiple test cases. The first line contains a single integer tt ( 1t1041 \leq t \leq 10^4 ) — the number of test cases. The description of the test cases follows.

The first line of each test case contains a single integer nn ( 1n21051\le n\le 2\cdot 10^5 ) — the size of the array aa .

The second line contains nn integers a1,a2,,ana_1, a_2, \ldots, a_n ( 1ain1 \le a_i \le n ) — the elements of the array aa .

It is guaranteed that the sum of nn over all test cases does not exceed 21052\cdot 10^5 .

输出格式

For each test case, output a single integer representing the minimum possible penalty you will receive.

输入输出样例

  • 输入#1

    5
    5
    1 2 3 4 5
    8
    8 2 3 1 1 7 4 3
    5
    3 3 3 3 3
    1
    1
    2
    2 1

    输出#1

    3
    1
    0
    0
    0

说明/提示

In the first test case, a possible way to split aa is s=[2,4,5]s=[2,4,5] and t=[1,3]t=[1,3] . The penalty is p(s)+p(t)=2+1=3p(s)+p(t)=2 + 1 =3 .

In the second test case, a possible way to split aa is s=[8,3,1]s=[8,3,1] and t=[2,1,7,4,3]t=[2,1,7,4,3] . The penalty is p(s)+p(t)=0+1=1p(s)+p(t)=0 + 1 =1 .

In the third test case, a possible way to split aa is s=[]s=[\,] and t=[3,3,3,3,3]t=[3,3,3,3,3] . The penalty is p(s)+p(t)=0+0=0p(s)+p(t)=0 + 0 =0 .

首页