codeforces#P2064E. Mycraft Sand Sort
Mycraft Sand Sort
Description
Steve has a permutation$^{\text{∗}}$ $p$ and an array $c$, both of length $n$. Steve wishes to sort the permutation $p$.
Steve has an infinite supply of coloured sand blocks, and using them he discovered a physics-based way to sort an array of numbers called gravity sort. Namely, to perform gravity sort on $p$, Steve will do the following:
- For all $i$ such that $1 \le i \le n$, place a sand block of color $c_i$ in position $(i, j)$ for all $j$ where $1 \le j \le p_i$. Here, position $(x, y)$ denotes a cell in the $x$-th row from the top and $y$-th column from the left.
- Apply downwards gravity to the array, so that all sand blocks fall as long as they can fall.

Alex looks at Steve's sand blocks after performing gravity sort and wonders how many pairs of arrays $(p',c')$ where $p'$ is a permutation would have resulted in the same layout of sand. Note that the original pair of arrays $(p, c)$ will always be counted.
Please calculate this for Alex. As this number could be large, output it modulo $998\,244\,353$.
$^{\text{∗}}$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 a $4$ in the array).
The first line contains an integer $t$ ($1 \le t \le 10^4$) — the number of test cases.
The first line of each testcase contains an integer $n$ ($1 \le n \le 2 \cdot 10^5$) — the lengths of the arrays.
The second line of each testcase contains $n$ distinct integers $p_1,p_2,\ldots,p_n$ ($1 \le p_i \le n$) — the elements of $p$.
The following line contains $n$ integers $c_1,c_2,\ldots,c_n$ ($1 \le c_i \le n$) — the elements of $c$.
The sum of $n$ across all testcases does not exceed $2 \cdot 10^5$.
For each testcase, output the number of pairs of arrays $(p', c')$ Steve could have started with, modulo $998\,244\,353$.
Input
The first line contains an integer $t$ ($1 \le t \le 10^4$) — the number of test cases.
The first line of each testcase contains an integer $n$ ($1 \le n \le 2 \cdot 10^5$) — the lengths of the arrays.
The second line of each testcase contains $n$ distinct integers $p_1,p_2,\ldots,p_n$ ($1 \le p_i \le n$) — the elements of $p$.
The following line contains $n$ integers $c_1,c_2,\ldots,c_n$ ($1 \le c_i \le n$) — the elements of $c$.
The sum of $n$ across all testcases does not exceed $2 \cdot 10^5$.
Output
For each testcase, output the number of pairs of arrays $(p', c')$ Steve could have started with, modulo $998\,244\,353$.
4
1
1
1
5
5 3 4 1 2
1 1 1 1 1
5
4 2 3 1 5
2 1 4 1 5
40
29 15 20 35 37 31 27 1 32 36 38 25 22 8 16 7 3 28 11 12 23 4 14 9 39 13 10 30 6 2 24 17 19 5 34 18 33 26 40 21
3 1 2 2 1 2 3 1 1 1 1 2 1 3 1 1 3 1 1 1 2 2 1 3 3 3 2 3 2 2 2 2 1 3 2 1 1 2 2 2
1
120
1
143654893
Note
The second test case is shown below.

It can be shown that permutations of $p$ will yield the same result, and that $c$ must equal $[1,1,1,1,1]$ (since all sand must be the same color), so the answer is $5! = 120$.
The third test case is shown in the statement above. It can be proven that no other arrays $p$ and $c$ will produce the same final result, so the answer is $1$.