P10060 [SNOI2024] 树 V 图

题目描述

你有一棵 $n$ 个点的无根树,节点的编号为 $1, 2, \ldots, n$。定义树上两点之间的距离 $\operatorname{dis}(i, j)$ 为树上 $i$ 点到 $j$ 点的简单路径上的边数。 现在有 $k$ 个关键点 $a_1, a_2, \ldots, a_k$,对于每个点,我们想求出距离它最近的关键点是哪个点。也就是对于一个点 $v$,令 $f(v)$ 表示令 $\operatorname{dis}(v, a_i)$ 最小的 $i$,如果有多个 $i$ 满足条件,那么我们会选择其中最小的 $i$。 现在,我们给出了 $f(1), f(2), \ldots, f(n)$,问有多少组可能的 $(a_1, a_2, \ldots, a_k)$ 满足条件。由于答案可能很大,输出对 $998244353$ 取模的结果。

输入格式

多组测试数据,第一行一个整数 $T$ 表示数据组数。 对于每组测试数据,第一行两个整数 $n, k$,表示节点个数和关键点个数。 接下来 $n - 1$ 行,每行两个整数 $u, v$,表示一条树边 $(u, v)$。 接下来一行,$n$ 个整数,$f(1), f(2), \ldots, f(n)$。注意:数据**不保证**一定存在一组可能的 $(a_1, a_2, \ldots, a_k)$。

输出格式

对于每组数据,输出一个整数,表示答案对 $998244353$ 取模的结果。

说明/提示

**【样例 \#1 解释】** 在第一个样例中,对于第二组数据,一个解为 $(1, 2)$。对于第三组数据,两个解为 $(2, 1), (3, 1)$。 注意,当多个点距离相同时,我们选择的是最小的 $i$ 而不是 $a_i$。 --- **【样例 \#3】** 见附件中 `voronoi/voronoi3.in` 与 `voronoi/voronoi3.ans`,这个样例满足测试点 $3 \sim 4$ 的条件限制。 --- **【样例 \#4】** 见附件中 `voronoi/voronoi3.in` 与 `voronoi/voronoi3.ans`,这个样例满足测试点 $7 \sim 10$ 的条件限制。 --- **【数据范围】** 对于所有的数据,保证 $1 \le T \le 10$,$2 \le k \le n \le 3 \times {10}^3$,$1 \le f(i) \le k$。 具体如下: | 测试点编号 | $n \le$ | 特殊性质 | |:-:|:-:|:-:| | $1 \sim 2$ | $15$ | 无 | | $3 \sim 4$ | $3000$ | A | | $5 \sim 6$ | $3000$ | B | | $7 \sim 10$ | $3000$ | 无 | 特殊性质 A:保证树是一条链。 特殊性质 B:保证 $k = 2$。