CF2187F2.Al Fine (Counting Version)

NOI/NOI+/CTSC

通过率:0%

AC君温馨提醒

该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。

题目描述

这是该问题的计数版本。与其他版本的不同之处在于,本版本需要你计算不同的公共树的数量。同时,本版本中 nn 的范围较小。只有在你解决了该问题的所有版本后,才能进行 hack。

在圣诞节,Tortinita 和 Arietta 各自收到了一棵圣诞树。巧合的是,她们的圣诞树都具有相同的性质:都有 n+1n+1 个结点,并且以 00 号结点为根。在给你的圣诞贺卡中,她们分别将各自树的 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,,ana_0, a_1, \ldots, a_n,Arietta 的树的 DFS 序列为 b0,b1,,bnb_0, b_1, \ldots, b_n。你注意到 a0=b0=0a_0 = b_0 = 0,由于她们是双胞胎姐妹,你好奇她们是否可能拥有完全相同的树。因此,你想找到两种序列下所有“公共树” ^{\ast} 的不同个数。由于答案可能非常大,你需要输出它对 998244353998\,244\,353 取模的结果。

^{\ast} 若存在某个结点,其子结点编号的集合在两棵树中不同,则认为这两棵树是不同的。换句话说,对于任意结点,子结点的顺序无关紧要,只有其子结点的集合一致才认为是一棵相同的树。

输入格式

每个测试点包含多组测试用例。第一行包含一个整数 tt1t1041 \le t \le 10^4),表示测试用例的数量。

每个测试用例的第一行包含一个整数 nn2n50002 \le n \le \boldsymbol{5000})。

第二行为 nn 个整数 a1,a2,,ana_1, a_2, \cdots, a_n1ain1 \le a_i \le n)。

第三行为 nn 个整数 b1,b2,,bnb_1, b_2, \cdots, b_n1bin1 \le b_i \le n)。

保证序列 aabb 均无重复元素。

保证所有测试用例中 n2n^2 的和不超过 2.51072.5 \cdot 10^7

输出格式

对于每个测试用例,输出一个整数,表示不同“公共树”的数量,对 998244353998\,244\,353 取模。

输入输出样例

  • 输入#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。

首页