Description
欧艾大陆上有 n 座城市,城市从 1∼n 编号,所有城市经由 n−1 条无向道路互相连通,即 n 座城市与 n−1 条道路构成了一棵树。
每座城市的集市上都会出售宝石,总共有 m 种不同的宝石,用 1∼m 编号。i 号城市的集市出售的是第 wi 种宝石,一种宝石可能会在多座城市的集市出售。
K 神有一个宝石收集器。这个宝石收集器能按照顺序收集至多 c 颗宝石,其收集宝石的顺序为: P1,P2,…,Pc。更具体地,收集器需要先放入第 P1 种宝石,然后才能再放入第 P2 种宝石,之后再能放入第 P3 种宝石,以此类推。其中 P1,P2,…,Pc 互不相等。
K 神到达一个城市后,如果该城市的集市上出售的宝石种类和当前收集器中需要放入的种类相同,则他可以在该城市的集市上购买一颗宝石并放入宝石收集器中;否则他只会路过该城市什么都不做。
现在 K 神给了你 q 次询问,每次给出起点 si 与终点 ti,他想知道如果从 si 号城市出发,沿最短路线走到 ti 号城市后,他的收集器中最多能收集到几个宝石?(在每次询问中,收集器内初始时没有任何宝石。起点与终点城市集市上的宝石可以尝试被收集)
Input
第一行,包含三个正整数 n,m,c,分别表示城市数,宝石种类数,收集器的容量。
第二行,包含 c 个正整数 Pi。数据保证 1≤Pi≤m 且这些数互不相等。
第三行,包含 n 个正整数 wi,表示每个城市集市上出售的宝石种类。
接下来 n−1 行,每行两个正整数 ui,vi,表示一条连接 ui 和 vi 号城市的道路。
接下来一行,包含一个正整数 q,表示询问次数。
接下来 q 行,每行两个正整数 si,ti,表示该次询问的起点与终点。
Output
按输入顺序输出 q 行,每行一个整数,表示询问的答案。
7 3 3
2 3 1
2 1 3 3 2 1 3
1 2
2 3
1 4
4 5
4 6
6 7
5
3 5
1 3
7 3
5 7
7 5