CFCF2154F2.Bombing (Hard Version)
NOI/NOI+/CTSC
通过率:0%
AC君温馨提醒
该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。
题目描述
这是该问题的难度较高版本。此版本与其他版本的区别在于本题中 n≤106。只有在你解决了该问题所有版本后,才能进行 Hack。
若满足 ∣a∣=∣b∣ 并存在 k,使得 1≤k<∣a∣,并且 a1,a2,…,ak 与 ak+1,ak+2,…,a∣a∣ 都是 b 的子序列 †,则称排列 b 是排列 a 的一次 riffle shuffle。
例如,[1,4,5,2,3,6] 是 [1,2,3,4,5,6] 的一次 riffle shuffle,因为可以选 k=3,且 [1,2,3] 与 [4,5,6] 都是子序列。
你得到一个长度为 n 的排列 p,其中某些值被替换成了 −1。请你计算将每个 −1 替换为整数的方案数,使得 p 变为 [1,2,…,n] (升序排列)的 riffle shuffle。
由于方案数可能非常大,请将结果对 998244353 取模后输出。
∗ 长度为 n 的排列是 1 到 n 的 n 个不同整数的任意排列。例如,[2,3,1,5,4] 是排列,但 [1,2,2] 不是(2 出现了两次),[1,3,4] 也不是(n=3,但出现了 4)。
† 如果序列 c 可以通过从序列 d 中删除若干(可能为零或全部)任意位置的元素获得,则 c 是 d 的子序列。
输入格式
每个测试点包含多组测试用例。第一行包含测试用例数 t(1≤t≤104)。接下来是具体的测试用例。
每个测试用例的第一行包含一个整数 n(2≤n≤106)——排列的长度。
每个测试用例的第二行包含 n 个整数 p1,p2,…,pn(1≤pi≤n 或 pi=−1),表示排列 p 的元素。其中非 −1 的元素互不相同。
所有测试用例中 n 的总和不超过 106。
输出格式
对于每个测试用例,输出填充 p 使其成为 [1,2,…,n] 的 riffle shuffle 的方案数,对 998244353 取模。
输入输出样例
输入#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],
- [1,4,5,2,3],
- [3,1,4,2,5],
- [3,4,1,2,5],
- [4,1,5,2,3],
- [4,5,1,2,3]。