#P6073. 「2017 山东一轮集训 Day5」距离

「2017 山东一轮集训 Day5」距离

题目描述

给定一棵 n n 个点的边带权的树,以及一个排列 p p ,有 q q 个询问,给定点 u,v,k u, v, k ,设 path(u,v) \text{path}(u, v) 表示 u u v v 的路径,dist(u,v) \text{dist}(u, v) 表示 u u v v 的距离,希望你求出

$$\sum\limits_{i \in \text{path}(u, v)} \text{dist}(p_i, k) $$

输入格式

第一行一个整数 type \text{type} 表示这个测试点的数据类型。
第二行两个整数 n,q n, q
接下来 n1 n - 1 行,每行三个整数 ui,vi,ci u_i, v_i, c_i ,代表树上有一条连接 ui,vi u_i, v_i 的权值为 ci c_i 的边。
接下来一行 n n 个正整数表示给定的排列 p p
接下来 q q 行,每行三个整数 u,v,k u', v', k' ,记 lastAns \text{lastAns} 为上一次询问的答案,假如这是第一次则 lastAns=0 \text{lastAns} = 0 ,那么这个询问对应的 u,v,k u, v, k 满足 $ u = u' \mathbin{\text{xor}} (\text{lastAns} \times \text{type}), v = v' \mathbin{\text{xor}} (\text{lastAns} \times \text{type}), k = k' \mathbin{\text{xor}} (\text{lastAns} \times \text{type}) $。

输出格式

输出 q q 行,代表每个询问的答案。

0
5 3
1 5 3
1 3 9
1 2 10
1 4 7
1 3 5 2 4
5 4 5
2 3 3
4 3 1
26
21
13

数据范围与提示

对于 20% 20\% 的数据,n,q5000 n, q \leq 5000
对于 40% 40\% 的数据,n,q50000 n, q \leq 50000
对于另外 10% 10\% 的数据,pi=i p_i = i
对于另外 20% 20\% 的数据,type=0 \text{type} = 0
对于 100% 100\% 的数据,$ 1 \leq n, q \leq 200000; 0 \leq c_i \leq 10 ^ 9; 1 \leq u, v, k \leq n $。