CF2170B Addition on a Segment

题目描述

你有一个整数数组 $a$,其初始包含 $n$ 个零。你需要执行恰好 $n$ 次如下操作: - 选择两个整数 $l$ 和 $r$($1 \le l \le r \le n$),并对所有满足 $l \le i \le r$ 的 $i$,执行 $a_{i} = a_{i} + 1$。 现给定另一个长度为 $n$ 的整数数组 $b$,你的任务是为每一次操作选择合适的 $l$ 和 $r$,使得: - 所有 $n$ 次操作执行结束后,可以通过重新排列 $a$ 数组的元素,使 $a$ 变为 $b$; - 在所有操作中,$r - l + 1$ 的最大值尽可能大。 请你求出 $r - l + 1$ 的最大可能值。

输入格式

每组测试包含多个测试用例。第一行包含一个整数 $t$($1 \le t \le 10^4$),表示测试用例的数量。 每个测试用例的第一行包含一个整数 $n$($1 \le n \le 2 \times 10^5$)——表示数组 $b$ 的长度。 每个测试用例的第二行包含 $n$ 个整数 $b_{i}$($0 \le b_{i} \le n$)——表示数组 $b$ 的各个元素。 输入的额外约束: - 至少存在一种方案可以选择每次操作的 $l$ 和 $r$,并在最后重排元素,将 $a$ 变为 $b$; - 所有测试用例中 $n$ 的总和不超过 $2 \times 10^5$。

输出格式

对于每个测试用例,输出一个整数,表示最大的 $r - l + 1$。

说明/提示

以第一个测试用例为例。如果 $n$ 次操作如下: - $l = 3$,$r = 3$ - $l = 1$,$r = 3$ - $l = 3$,$r = 3$ - $l = 3$,$r = 3$ - $l = 3$,$r = 3$ 则数组 $a = [1, 1, 5, 0, 0]$,可重排为 $[0, 5, 1, 0, 1]$。可以看到,此时 $r - l + 1$ 的最大值为 $3$,且这是最优答案。 第二个测试用例: - $l = 1$,$r = 3$ - $l = 2$,$r = 3$ - $l = 3$,$r = 3$ 此时答案为 $3$。 由 ChatGPT 5 翻译