310891: CF1905F. Field Should Not Be Empty

Memory Limit:256 MB Time Limit:2 S
Judge Style:Text Compare Creator:
Submit:0 Solved:0

Description

F. Field Should Not Be Emptytime limit per test2 secondsmemory limit per test256 megabytesinputstandard inputoutputstandard output

You are given a permutation$^{\dagger}$ $p$ of length $n$.

We call index $x$ good if for all $y < x$ it holds that $p_y < p_x$ and for all $y > x$ it holds that $p_y > p_x$. We call $f(p)$ the number of good indices in $p$.

You can perform the following operation: pick $2$ distinct indices $i$ and $j$ and swap elements $p_i$ and $p_j$.

Find the maximum value of $f(p)$ after applying the aforementioned operation exactly once.

$^{\dagger}$A permutation of length $n$ is an array consisting of $n$ distinct integers from $1$ to $n$ in arbitrary order. For example, $[2,3,1,5,4]$ is a permutation, but $[1,2,2]$ is not a permutation ($2$ appears twice in the array), and $[1,3,4]$ is also not a permutation ($n=3$ but there is $4$ in the array).

Input

Each test consists of multiple test cases. The first line of contains a single integer $t$ ($1 \le t \le 2 \cdot 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 $n$ ($2 \le n \le 2 \cdot 10^5$) — the length of the permutation $p$.

The second line of each test case contain $n$ distinct integers $p_1, p_2, \ldots, p_n$ ($1 \le p_i \le n$) — the elements of the permutation $p$.

It is guaranteed that sum of $n$ over all test cases does not exceed $2 \cdot 10^5$.

Output

For each test case, output a single integer — the maximum value of $f(p)$ after performing the operation exactly once.

ExampleInput
5
5
1 2 3 4 5
5
2 1 3 4 5
7
2 1 5 3 7 6 4
6
2 3 5 4 1 6
7
7 6 5 4 3 2 1
Output
3
5
2
3
2
Note

In the first test case, $p = [1,2,3,4,5]$ and $f(p)=5$ which is already maximum possible. But must perform the operation anyway. We can get $f(p)=3$ by choosing $i=1$ and $j=2$ which makes $p = [2,1,3,4,5]$.

In the second test case, we can transform $p$ into $[1,2,3,4,5]$ by choosing $i=1$ and $j=2$. Thus $f(p)=5$.

Output

题目大意:
给定一个长度为n的排列p。如果对于所有的yx,都有p_y>p_x,则称索引x是好的。函数f(p)返回排列p中好的索引的数量。可以进行一次操作:选择两个不同的索引i和j,并交换元素p_i和p_j。求在执行上述操作恰好一次后,f(p)的最大值。

输入数据格式:
第一行包含一个整数t(1≤t≤2×10^4)——测试用例的数量。接下来是t个测试用例的描述。
每个测试用例的第一行包含一个整数n(2≤n≤2×10^5)——排列p的长度。
每个测试用例的第二行包含n个不同的整数p_1, p_2, …, p_n(1≤p_i≤n)——排列p的元素。
保证所有测试用例的n之和不超过2×10^5。

输出数据格式:
对于每个测试用例,输出一个整数——执行操作一次后f(p)的最大值。

例:
输入
5
5
1 2 3 4 5
5
2 1 3 4 5
7
2 1 5 3 7 6 4
6
2 3 5 4 1 6
7
7 6 5 4 3 2 1
输出
3
5
2
3
2

说明:
在第一个测试用例中,p = [1,2,3,4,5]且f(p)=5,这已经是可能的最大值。但我们必须执行操作。我们可以通过选择i=1和j=2,使得p = [2,1,3,4,5],从而得到f(p)=3。
在第二个测试用例中,我们可以通过选择i=1和j=2将p转换为[1,2,3,4,5]。因此f(p)=5。题目大意: 给定一个长度为n的排列p。如果对于所有的yx,都有p_y>p_x,则称索引x是好的。函数f(p)返回排列p中好的索引的数量。可以进行一次操作:选择两个不同的索引i和j,并交换元素p_i和p_j。求在执行上述操作恰好一次后,f(p)的最大值。 输入数据格式: 第一行包含一个整数t(1≤t≤2×10^4)——测试用例的数量。接下来是t个测试用例的描述。 每个测试用例的第一行包含一个整数n(2≤n≤2×10^5)——排列p的长度。 每个测试用例的第二行包含n个不同的整数p_1, p_2, …, p_n(1≤p_i≤n)——排列p的元素。 保证所有测试用例的n之和不超过2×10^5。 输出数据格式: 对于每个测试用例,输出一个整数——执行操作一次后f(p)的最大值。 例: 输入 5 5 1 2 3 4 5 5 2 1 3 4 5 7 2 1 5 3 7 6 4 6 2 3 5 4 1 6 7 7 6 5 4 3 2 1 输出 3 5 2 3 2 说明: 在第一个测试用例中,p = [1,2,3,4,5]且f(p)=5,这已经是可能的最大值。但我们必须执行操作。我们可以通过选择i=1和j=2,使得p = [2,1,3,4,5],从而得到f(p)=3。 在第二个测试用例中,我们可以通过选择i=1和j=2将p转换为[1,2,3,4,5]。因此f(p)=5。

加入题单

上一题 下一题 算法标签: