[AHOI2022] 钥匙

题目描述

有 $n$ 座城市,编号为 $1, 2, \ldots, n$。这些城市由 $n - 1$ 条无向道路相连,每条无向道路连接两座城市,保证任意两个城市连通。即这 $n$ 座城市构成一棵树。 每座城市都有一件宝物。宝物分为两种:钥匙和宝箱。在一座城市里,要么有一把钥匙,要么有一个宝箱。钥匙和宝箱有不同的颜色,颜色为 $i$ 的钥匙只能打开颜色为 $i$ 的宝箱,打开宝箱后可以获得一枚金币,同时这把钥匙会损坏。 **由于某种特殊的原因,同一种的钥匙最多只有 $\bm{5}$ 把(同一种颜色的宝箱数量不限)。** 现在小 R 规划了 $m$ 次旅行,第 $i$ 次旅行的起点为 $s_i$,终点为 $e_i$。小 R 从 $s_i$ 沿最短路径走到 $e_i$。当他走到一座有钥匙的城市时,他可以将钥匙放入背包。当他走到一座有宝箱的城市时,如果他有相应颜色的钥匙,那么他就会打开这个宝箱并获得一个金币;如果他没有相应颜色的钥匙,那么他什么都不做(宝箱不能带走)。问每次旅行能获得多少枚金币。 **注意:旅行相互独立,即一次旅行完之后所有的钥匙和宝箱都会恢复到初始状态。**

输入输出格式

输入格式


第一行两个正整数 $n, m$,表示城市数量和旅行数量。 接下来 $n$ 行,每行两个正整数 $t_i, c_i$,$t_i=1$ 表示第 $i$ 个城市里有一把钥匙,$t_i=2$ 表示有一个宝箱。$c_i$ 表示第 $i$ 座城市里钥匙或宝箱的颜色。数据保证每种颜色的钥匙都不超过 $5$ 把。 接下来 $n - 1$ 行,每行两个正整数 $u_i, v_i$,表示有一条连接 $u_i$ 和 $v_i$ 的无向道路。 接下来 $m$ 行,每行两个正整数 $s_i, e_i$ 表示一次旅行的起点和终点。

输出格式


输出 $m$ 行,每行一个整数,表示第 $i$ 次旅行能获得的金币数量。

输入输出样例

输入样例 #1

5 3
1 2
2 2
1 3
2 3
2 2
1 2
1 3
3 4
3 5
2 4
2 5
4 2

输出样例 #1

1
1
1

输入样例 #2

见附件中的 keys/keys2.in

输出样例 #2

见附件中的 keys/keys2.ans

输入样例 #3

见附件中的 keys/keys3.in

输出样例 #3

见附件中的 keys/keys3.ans

说明

**【样例 \#4】** 见附件中的 `keys/keys4.in` 与 `keys/keys4.ans`。 该组样例满足 $n, m \le {10}^5$ 和特殊性质 A。 **【数据范围】** 对于 $100 \%$ 的数据,$1 \le n \le 5 \times {10}^5$,$1 \le m \le {10}^6$,$1 \le t_i \le 2$,$1 \le c_i, u_i, v_i, s_i, e_i \le n$,每种颜色的钥匙都不超过 $5$ 把。 | 测试点编号 | $n \le$ | $m \le$ | 特殊性质 | |:-:|:-:|:-:|:-:| | $1$ | $100$ | $100$ | 无 | | $2 \sim 3$ | $5000$ | $5000$ | 无 | | $4 \sim 5$ | ${10}^5$ | ${10}^5$ | 无 | | $6 \sim 8$ | $5 \times {10}^5$ | ${10}^6$ | A | | $9 \sim 10$ | $5 \times {10}^5$ | ${10}^6$ | 无 | 特殊性质 A:对于每种出现过的颜色,恰有一把钥匙和一个宝箱对应该颜色。 **【提示】** 输入输出数据较大,请使用较为快速的输入输出方式。