Logo 邂逅编程之美

UOJ

时间限制:4 s 空间限制:512 MB
统计

题目描述

有 $n$ 座城市,编号为 $1, 2, \ldots, n$。这些城市由 $n - 1$ 条无向道路相连,每条无向道路连接两座城市,保证任意两个城市连通。即这 $n$ 座城市构成一棵树。

每座城市都有一件宝物。宝物分为两种:钥匙和宝箱。在一座城市里,要么有一把钥匙,要么有一个宝箱。钥匙和宝箱有不同的颜色,颜色为 $i$ 的钥匙只能打开颜色为 $i$ 的宝箱,打开宝箱后可以获得一枚金币,同时这把钥匙会损坏。

由于某种特殊的原因,同一种的钥匙最多只有 $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

样例输入 #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

样例输入 #2

见附件中的 keys/keys2.in

样例输出 #2

见附件中的 keys/keys2.ans

样例 #3

样例输入 #3

见附件中的 keys/keys3.in

样例输出 #3

见附件中的 keys/keys3.ans

提示

【样例 #4】

见附件中的 keys/keys4.inkeys/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:对于每种出现过的颜色,恰有一把钥匙和一个宝箱对应该颜色。

【提示】

输入输出数据较大,请使用较为快速的输入输出方式。