100 atcoder#ABC070D. [ABC070D] Transit Tree Path

[ABC070D] Transit Tree Path

题目描述

N N 頂点の木が与えられます。
木とはグラフの一種であり、頂点の数を N N とすると、辺の数が N1 N-1 本である閉路のない連結グラフです。
i(1iN1) i(1≦i≦N-1) 番目の辺は 頂点 ai a_i と 頂点 bi b_i を距離 ci c_i で結びます。

また、Q Q 個の質問クエリと整数 K K が与えられます。

  • j(1jQ) j(1≦j≦Q) 番目の質問クエリでは、頂点 xj x_j から 頂点 K K を経由しつつ、頂点 yj y_j まで移動する場合の最短経路の距離を求めてください。

输入格式

入力は以下の形式で標準入力から与えられる。

N N a1 a_1 b1 b_1 c1 c_1 : : aN1 a_{N-1} bN1 b_{N-1} cN1 c_{N-1} Q Q K K x1 x_1 y1 y_1 : : xQ x_{Q} yQ y_{Q}

输出格式

質問クエリの解答を Q Q 行出力せよ。
j(1jQ) j(1≦j≦Q) 行目には、j j 番目のクエリの答えを出力せよ。

题目大意

给出一棵有N个结点的树,给出Q个询问,求结点xj过结点K到节点yj的最短距离

5
1 2 1
1 3 1
2 4 1
3 5 1
3 1
2 4
2 3
4 5
3
2
4
7
1 2 1
1 3 3
1 4 5
1 5 7
1 6 9
1 7 11
3 2
1 3
4 5
6 7
5
14
22
10
1 2 1000000000
2 3 1000000000
3 4 1000000000
4 5 1000000000
5 6 1000000000
6 7 1000000000
7 8 1000000000
8 9 1000000000
9 10 1000000000
1 1
9 10
17000000000

提示

制約

  • 3N105 3≦N≦10^5
  • 1ai,biN (1iN1) 1≦a_i,b_i≦N\ (1≦i≦N-1)
  • 1ci109 (1iN1) 1≦c_i≦10^9\ (1≦i≦N-1)
  • 与えられるグラフは木である。
  • 1Q105 1≦Q≦10^5
  • 1KN 1≦K≦N
  • 1xj,yjN (1jQ) 1≦x_j,y_j≦N\ (1≦j≦Q)
  • xjyj (1jQ) x_j≠y_j\ (1≦j≦Q)
  • xjK,yjK (1jQ) x_j≠K,y_j≠K\ (1≦j≦Q)

Sample Explanation 1

与えられた 3 3 つの質問クエリに対する最短経路は以下の通りです。 - 1 1 つ目の質問クエリ: 頂点 2 2 → 頂点 1 1 → 頂点 2 2 → 頂点 4 4 : 距離 1+1+1=3 1+1+1=3 - 2 2 つ目の質問クエリ: 頂点 2 2 → 頂点 1 1 → 頂点 3 3 : 距離 1+1=2 1+1=2 - 3 3 つ目の質問クエリ: 頂点 4 4 → 頂点 2 2 → 頂点 1 1 → 頂点 3 3 → 頂点 5 5 : 距離 1+1+1+1=4 1+1+1+1=4

Sample Explanation 2

質問クエリに対する最短経路は、必ず頂点 K=2 K=2 を通過する必要があります。