310918: CF1909F2. Small Permutation Problem (Hard Version)

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

Description

F2. Small Permutation Problem (Hard Version)time limit per test2 secondsmemory limit per test256 megabytesinputstandard inputoutputstandard outputAndy Tunstall - MiniBoss

In the easy version, the $a_i$ are in the range $[0, n]$; in the hard version, the $a_i$ are in the range $[-1, n]$ and the definition of good permutation is slightly different. You can make hacks only if all versions of the problem are solved.

You are given an integer $n$ and an array $a_1, a_2, \dots, a_n$ of integers in the range $[-1, n]$.

A permutation $p_1, p_2, \dots, p_n$ of $[1, 2, \dots, n]$ is good if, for each $i$, the following condition is true:

  • if $a_i \neq -1$, the number of values $\leq i$ in $[p_1, p_2, \dots, p_i]$ is exactly $a_i$.

Count the good permutations of $[1, 2, \dots, n]$, modulo $998\,244\,353$.

Input

Each test contains multiple test cases. The first line contains the number of test cases $t$ ($1 \le t \le 10^4$). The description of the test cases follows.

The first line of each test case contains a single integer $n$ ($1 \leq n \leq 2 \cdot 10^5$) — the length of the array $a$.

The second line of each test case contains $n$ integers $a_1, a_2, \ldots, a_n$ ($-1 \le a_i \le n$), which describe the conditions for a good permutation.

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

Output

For each test case, output a single line containing the number of good permutations, modulo $998\,244\,353$.

ExampleInput
10
5
-1 -1 -1 -1 -1
5
1 2 3 4 5
6
0 2 2 2 -1 -1
6
-1 -1 -1 -1 -1 5
6
-1 -1 3 2 -1 -1
15
0 0 -1 -1 -1 2 2 -1 -1 -1 -1 9 11 13 15
6
0 2 2 2 4 6
6
0 1 3 4 5 5
6
1 2 3 2 4 6
15
0 0 1 1 1 2 3 4 5 6 7 9 11 13 15
Output
120
1
4
0
0
494403526
4
0
0
532305727
Note

In the first test case, all the permutations of length $5$ are good, so there are $120$ good permutations.

In the second test case, the only good permutation is $[1, 2, 3, 4, 5]$.

In the third test case, there are $4$ good permutations: $[2, 1, 5, 6, 3, 4]$, $[2, 1, 5, 6, 4, 3]$, $[2, 1, 6, 5, 3, 4]$, $[2, 1, 6, 5, 4, 3]$. For example, $[2, 1, 5, 6, 3, 4]$ is good because:

  • $a_1 = 0$, and there are $0$ values $\leq 1$ in $[p_1] = [2]$;
  • $a_2 = 2$, and there are $2$ values $\leq 2$ in $[p_1, p_2] = [2, 1]$;
  • $a_3 = 2$, and there are $2$ values $\leq 3$ in $[p_1, p_2, p_3] = [2, 1, 5]$;
  • $a_4 = 2$, and there are $2$ values $\leq 4$ in $[p_1, p_2, p_3, p_4] = [2, 1, 5, 6]$;
  • $a_5 = -1$, so there are no restrictions on $[p_1, p_2, p_3, p_4, p_5]$;
  • $a_6 = -1$, so there are no restrictions on $[p_1, p_2, p_3, p_4, p_5, p_6]$.

Output

题目大意:

给定一个整数n和一个整数数组a_1, a_2, ..., a_n,其中a_i的范围为[-1, n]。

定义一个[1, 2, ..., n]的排列p_1, p_2, ..., p_n为好的排列,如果对于每个i,满足以下条件:

如果a_i ≠ -1,那么在[p_1, p_2, ..., p_i]中小于等于i的数的个数正好是a_i。

计算[1, 2, ..., n]的所有好的排列的数量,对998,244,353取模。

输入数据格式:

每个测试包含多个测试用例。第一行包含测试用例的数量t(1 ≤ t ≤ 10^4)。接下来是每个测试用例的描述。

每个测试用例的第一行包含一个整数n(1 ≤ n ≤ 2 * 10^5)——数组a的长度。

第二行包含n个整数a_1, a_2, ..., a_n(-1 ≤ a_i ≤ n),描述好的排列的条件。

保证所有测试用例的n之和不超过2 * 10^5。

输出数据格式:

对于每个测试用例,输出一行,包含好的排列的数量,对998,244,353取模。题目大意: 给定一个整数n和一个整数数组a_1, a_2, ..., a_n,其中a_i的范围为[-1, n]。 定义一个[1, 2, ..., n]的排列p_1, p_2, ..., p_n为好的排列,如果对于每个i,满足以下条件: 如果a_i ≠ -1,那么在[p_1, p_2, ..., p_i]中小于等于i的数的个数正好是a_i。 计算[1, 2, ..., n]的所有好的排列的数量,对998,244,353取模。 输入数据格式: 每个测试包含多个测试用例。第一行包含测试用例的数量t(1 ≤ t ≤ 10^4)。接下来是每个测试用例的描述。 每个测试用例的第一行包含一个整数n(1 ≤ n ≤ 2 * 10^5)——数组a的长度。 第二行包含n个整数a_1, a_2, ..., a_n(-1 ≤ a_i ≤ n),描述好的排列的条件。 保证所有测试用例的n之和不超过2 * 10^5。 输出数据格式: 对于每个测试用例,输出一行,包含好的排列的数量,对998,244,353取模。

加入题单

上一题 下一题 算法标签: