100 atcoder#ABC070D. [ABC070D] Transit Tree Path

[ABC070D] Transit Tree Path

配点 : 400400

問題文

NN 頂点の木が与えられます。 木とはグラフの一種であり、頂点の数を NN とすると、辺の数が N1N-1 本である閉路のない連結グラフです。 i(1iN1)i(1 \leq i \leq N-1) 番目の辺は 頂点 aia_i と 頂点 bib_i を距離 cic_i で結びます。

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

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

制約

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

入力

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

NN

a1a_1 b1b_1 c1c_1

::

aN1a_{N-1} bN1b_{N-1} cN1c_{N-1}

QQ KK

x1x_1 y1y_1

::

xQx_{Q} yQy_{Q}

出力

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

5
1 2 1
1 3 1
2 4 1
3 5 1
3 1
2 4
2 3
4 5
3
2
4

与えられた 33 つの質問クエリに対する最短経路は以下の通りです。

  • 11 つ目の質問クエリ: 頂点 22 → 頂点 11 → 頂点 22 → 頂点 44 : 距離 1+1+1=31+1+1=3
  • 22 つ目の質問クエリ: 頂点 22 → 頂点 11 → 頂点 33 : 距離 1+1=21+1=2
  • 33 つ目の質問クエリ: 頂点 44 → 頂点 22 → 頂点 11 → 頂点 33 → 頂点 55 : 距離 1+1+1+1=41+1+1+1=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

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

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