CF1881E.Block Sequence

普及/提高-

通过率:0%

AC君温馨提醒

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

题目描述

给定一个由 nn 个正整数组成的序列 a1,a2,,ana_1, a_2, \dots, a_n

你可以执行任意次操作。每次操作中,你删除序列中的一个元素。删除元素后,剩下的元素保持原来的相对顺序。

操作结束后,剩下的序列应满足以下条件:可以将序列划分成若干个连续的块,使得每个块的第一个元素的值恰好等于该块的长度(即该块包含的元素个数)。

求最少需要删除多少个元素才能达到要求。

输入格式

第一行包含一个整数 tt1t1041 \le t \le 10^4)——测试用例的数量。

每个测试用例的第一行包含一个整数 nn1n21051 \le n \le 2 \cdot 10^5)。

每个测试用例的第二行包含 nn 个整数 a1,a2,,ana_1, a_2, \dots, a_n1ai1061 \le a_i \le 10^6)。

保证所有测试用例的 nn 之和不超过 21052 \cdot 10^5

输出格式

对于每个测试用例,输出一个整数——最少需要删除的元素个数。

输入输出样例

  • 输入#1

    7
    7
    3 3 4 5 2 6 1
    4
    5 6 3 2
    6
    3 4 1 6 7 7
    3
    1 4 3
    5
    1 2 3 4 5
    5
    1 2 3 1 2
    5
    4 5 5 1 5

    输出#1

    0
    4
    1
    1
    2
    1
    0

说明/提示

提示

  • 样例 1:删除第一个 11,剩下 [1,1][1, 1] 是一个长度为 22 的块,块首 121 \neq 2,但可以继续删……实际上最优是删 11 个元素。
  • 样例 2:[2,1,3,1][2, 1, 3, 1] 本身就是合法的——[2,1][2, 1] 是长度 22 的块(首元素 22),[3,1][3, 1] 是长度 22 的块(首元素 33,但注意这里块首是 33 而块长是 22——不对)。实际上需要按规则仔细验证。
  • 核心思路:dp[i]\mathit{dp}[i] 表示前 ii 个元素中最多能保留多少个(或最少删多少个),转移时要么删掉 aia_i,要么以 aia_i 开头形成一块。
首页