CFCF2154F1.Bombing (Easy Version)

省选/NOI-

通过率:0%

AC君温馨提醒

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

题目描述

这是本题的简单版本。不同版本的区别在于本版本中 n3000n \leq 3000。只有当你解决了所有版本的问题后,才可以进行 hack。

如果一个排列 bb 是排列 aa 的一次 “riffle shuffle”,需要满足 a=b|a| = |b|,并且存在一个 kk1k<a1 \leq k < |a|,使得 a1,a2,,aka_1,a_2,\ldots,a_kak+1,ak+2,,aaa_{k+1},a_{k+2},\ldots,a_{|a|} 都是 bb 的子序列。

例如,[1,4,5,2,3,6][\color{red}{1}, \color{blue}{4}, \color{blue}{5}, \color{red}{2}, \color{red}{3}, \color{blue}{6}][1,2,3,4,5,6][\color{red}{1}, \color{red}{2}, \color{red}{3}, \color{blue}{4}, \color{blue}{5}, \color{blue}{6}] 的一次 riffle shuffle,因为我们可以选 k=3k = 3,且 [1,2,3][\color{red}{1}, \color{red}{2}, \color{red}{3}][4,5,6][\color{blue}{4}, \color{blue}{5}, \color{blue}{6}] 都是子序列。

给定一个长度为 nn 的排列 pp,其中有些位置被替换为 1-1。请你计算有多少种方式将每个 1-1 替换为一个整数,使得 pp 变成 [1,2,,n][1,2,\ldots,n](即升序排列)的一个 riffle shuffle。

由于方案数可能非常大,请你输出其对 998244353998\,244\,353 取模的结果。

^* 一个长度为 nn 的排列是由 11nnnn 个互不相同的整数按任意顺序组成的数组。例如,[2,3,1,5,4][2,3,1,5,4] 是一个排列,但 [1,2,2][1,2,2] 不是(22 出现了两次),[1,3,4][1,3,4] 也不是(n=3n=3,但出现了 44)。

^\dagger 如果一个序列 cc 能通过从另一个序列 dd 删除若干(可以为零或全部)元素而得到,那么称 ccdd 的子序列。

输入格式

每个测试用例包含多组数据。第一行为测试用例个数 tt1t1001 \leq t \leq 100)。下接每组测试数据。

每组测试数据第一行为排列的长度 nn2n30002 \leq n \leq 3000)。

第二行为 nn 个整数 p1,p2,,pnp_1, p_2, \ldots, p_n1pin1 \leq p_i \leq npi=1p_i = -1)——排列 pp 的元素。所有非 1-1pip_i 两两不相同。

所有测试用例中 nn 的总和不超过 30003000

输出格式

对于每个测试用例,输出一个整数,表示将 pp 填补为 [1,2,,n][1,2,\ldots,n] 的一次 riffle shuffle 的方案数,对 998244353998\,244\,353 取模。

输入输出样例

  • 输入#1

    7
    5
    -1 -1 -1 -1 -1
    4
    1 2 3 4
    5
    -1 -1 -1 2 -1
    6
    -1 3 2 1 -1 -1
    18
    11 -1 2 -1 -1 -1 -1 6 -1 -1 14 8 9 15 -1 -1 -1 -1
    6
    -1 3 -1 4 -1 5
    3
    -1 2 1

    输出#1

    27
    1
    6
    0
    32
    0
    0

说明/提示

第三个测试用例可能的排列如下:

  • [1,3,4,2,5][\color{red}1, \color{blue}3, \color{blue}4, \color{red}2, \color{blue}5]
  • [1,4,5,2,3][\color{red}1, \color{blue}4, \color{blue}5, \color{red}2, \color{red}3]
  • [3,1,4,2,5][\color{blue}3, \color{red}1, \color{blue}4, \color{red}2, \color{blue}5]
  • [3,4,1,2,5][\color{blue}3, \color{blue}4, \color{red}1, \color{red}2, \color{blue}5]
  • [4,1,5,2,3][\color{blue}4, \color{red}1, \color{blue}5, \color{red}2, \color{red}3]
  • [4,5,1,2,3][\color{blue}4, \color{blue}5, \color{red}1, \color{red}2, \color{red}3]
首页