CF2187F2.Al Fine (Counting Version)
NOI/NOI+/CTSC
通过率:0%
AC君温馨提醒
该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。
题目描述
这是该问题的计数版本。与其他版本的不同之处在于,本版本需要你计算不同的公共树的数量。同时,本版本中 n 的范围较小。只有在你解决了该问题的所有版本后,才能进行 hack。
在圣诞节,Tortinita 和 Arietta 各自收到了一棵圣诞树。巧合的是,她们的圣诞树都具有相同的性质:都有 n+1 个结点,并且以 0 号结点为根。在给你的圣诞贺卡中,她们分别将各自树的 DFS 序列添加在祝词后。回忆一下,DFS 序列的生成方式如下伪代码所示:
dfs_order = []
def dfs(v):
dfs_order.append(v)
pick an arbitrary permutation s of children of v
for child in s:
dfs(child)
dfs(root)
设 Tortinita 的树的 DFS 序列为 a0,a1,…,an,Arietta 的树的 DFS 序列为 b0,b1,…,bn。你注意到 a0=b0=0,由于她们是双胞胎姐妹,你好奇她们是否可能拥有完全相同的树。因此,你想找到两种序列下所有“公共树” ∗ 的不同个数。由于答案可能非常大,你需要输出它对 998244353 取模的结果。
∗ 若存在某个结点,其子结点编号的集合在两棵树中不同,则认为这两棵树是不同的。换句话说,对于任意结点,子结点的顺序无关紧要,只有其子结点的集合一致才认为是一棵相同的树。
输入格式
每个测试点包含多组测试用例。第一行包含一个整数 t(1≤t≤104),表示测试用例的数量。
每个测试用例的第一行包含一个整数 n(2≤n≤5000)。
第二行为 n 个整数 a1,a2,⋯,an(1≤ai≤n)。
第三行为 n 个整数 b1,b2,⋯,bn(1≤bi≤n)。
保证序列 a 和 b 均无重复元素。
保证所有测试用例中 n2 的和不超过 2.5⋅107。
输出格式
对于每个测试用例,输出一个整数,表示不同“公共树”的数量,对 998244353 取模。
输入输出样例
输入#1
4 2 1 2 1 2 2 1 2 2 1 5 3 5 1 2 4 3 1 5 4 2 5 2 1 4 5 3 2 4 1 5 3
输出#1
2 1 3 7
说明/提示
在第一个测试用例中,两棵不同的树分别为图中的树 A 和树 B。注意,树 B 和树 C 是相同的树。
在第二个测试用例中,唯一的公共树为图中的树 B。
