时间限制:每个测试点 5 秒
内存限制:每个测试点 1024 MB
给你一个长度为 n 的排列 p。
请计算满足以下条件的长为 n 的排列 q 的数量:
- 对每个 1≤i<n,有 max(q1,…,qi)=max(p1,…,pi)。
由于答案可能很大,输出答案对 998244353 取模。
输入格式
每个测试点包含多个测试用例。第一行包含测试用例数 t(1≤t≤104)。接下来是每个测试用例的描述。
每个测试用例的第一行包含一个整数 n(2≤n≤2⋅105)。
第二行包含 n 个整数 p1,p2,…,pn(1≤pi≤n)。保证 p 是一个排列。
保证所有测试用例的 n 之和不超过 2⋅105。
输出格式
对于每个测试用例,输出一个整数——答案对 998244353 取模的值。
示例
输入
6
2
2 1
3
1 2 3
3 1 2
4
2 4 1 3
5
3 5 1 4 2
15
6 13 2 8 7 11 1 3 9 15 4 5 12 10 14
输出
1
3
2
4
18
424488915
说明
在第一个测试用例中,p=[2,1]。唯一符合条件的 q 是 [1,2]。的确,我们需要满足 q1=p1,这只对 q=[1,2] 成立。
在第二个测试用例中,p=[1,2,3]。因此 q 需要满足两个不等式:q1=p1 以及 max(q1,q2)=max(1,2)=2。可以证明只有以下 3 个排列满足条件:
- q=[2,3,1]:此时 q1=2=1 且 max(q1,q2)=3=2;
- q=[3,1,2]:此时 q1=3=1 且 max(q1,q2)=3=2;
- q=[3,2,1]:此时 q1=3=1 且 max(q1,q2)=3=2。