loj#P3713. 「AHOI2022」钥匙
「AHOI2022」钥匙
题目描述
有 座城市,编号为 。这些城市由 条无向道路相连,每条无向道路连接两座城市,保证任意两个城市连通。即这 座城市构成一棵树。
每座城市都有一件宝物。宝物分为两种:钥匙和宝箱。在一座城市里,要么有一把钥匙,要么有一个宝箱。钥匙和宝箱有不同的颜色,颜色为 的钥匙只能打开颜色为 的宝箱,打开宝箱后可以获得一枚金币,同时这把钥匙会损坏。
由于某种特殊的原因,同一种的钥匙最多只有 把(同一种颜色的宝箱数量不限)。
现在小 R 规划了 次旅行,第 次旅行的起点为 ,终点为 。小 R 从 沿最短路径走到 。当他走到一座有钥匙的城市时,他可以将钥匙放入背包。当他走到一座有宝箱的城市时,如果他有相应颜色的钥匙,那么他就会打开这个宝箱并获得一个金币;如果他没有相应颜色的钥匙,那么他什么都不做(宝箱不能带走)。问每次旅行能获得多少枚金币。
注意:旅行相互独立,即一次旅行完之后所有的钥匙和宝箱都会恢复到初始状态。
输入格式
第一行两个正整数 ,表示城市数量和旅行数量。
接下来 行,每行两个正整数 , 表示第 个城市里有一把钥匙, 表示有一个宝箱。 表示第 座城市里钥匙或宝箱的颜色。数据保证每种颜色的钥匙都不超过 把。
接下来 行,每行两个正整数 ,表示有一条连接 和 的无向道路。
接下来 行,每行两个正整数 表示一次旅行的起点和终点。
输出格式
输出 行,每行一个整数,表示第 次旅行能获得的金币数量。
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
样例 2
见附加文件下的 [keys2.in
](file:keys2.in) 与 [keys2.ans
](file:keys2.ans)。
样例 3
见附加文件下的 [keys3.in
](file:keys3.in) 与 [keys3.ans
](file:keys3.ans)。
样例 4
见附加文件下的 [keys4.in
](file:keys4.in) 与 [keys4.ans
](file:keys4.ans)。
该组样例满足 和特殊性质 A。
数据范围与提示
对于 的数据,,,,,每种颜色的钥匙都不超过 把。
测试点编号 | 特殊性质 | ||
---|---|---|---|
无 | |||
A | |||
无 |
特殊性质 A:对于每种出现过的颜色,恰有一把钥匙和一个宝箱对应该颜色。
输入输出数据较大,请使用较为快速的输入输出方式。