#arc048d. [arc048_d]たこ焼き屋とQ人の高橋君

[arc048_d]たこ焼き屋とQ人の高橋君

問題文

AtCoder市には 11 から NN までの番号のついた NN 個の町があり、それらは N1N-1 本の双方向に通行可能な距離 11 の道路によって結ばれています。 どの町からどの町へも、いくつかの道を経由してたどり着くことが出来ます。

AtCoder市には高橋君が QQ 人おり、ii 人目の高橋君は町 sis_i から町 tit_i に行きたいです。

AtCoder市のいくつかの町にはたこ焼き屋があります。高橋君たちはみな、22 秒間に距離 11 進む速度で歩きますが、たこ焼き屋のある町でたこ焼きを食べたあとは歩く速度が 11 秒間に距離 11 進む速度になります。 また高橋君たちはみな小食なので、たこ焼きを複数回食べることはしません。もちろん、たこ焼き屋のある町をたこ焼きを食べずに通過することは可能です。 また、たこ焼きを食べずに町 tit_i に到着してもかまいません。

AtCoder市の町の接続関係が与えられるので、 QQ 人の高橋君すべてに対し、最適に行動したときの町 sis_i から町 tit_iへの移動に費やされる時間の最小値を求めてください。 高橋君たちはみなたこ焼きのプロなので、たこ焼きを食べるのにかかる時間は無視できるものとします。


入力

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

NN QQ A1A_1 B1B_1 . . . AN1A_{N-1} BN1B_{N-1} SS s1s_1 t1t_1 . . . sQs_Q tQt_Q

  • 11 行目には、整数 N(1N100000)N(1 ≦ N ≦ 100000)Q(1Q100000)Q(1 ≦ Q ≦ 100000) が空白を区切りとして与えられる。
  • 続く N1N-1 行には、 ii 番目の道の情報を表す整数 Ai,Bi(1AiN,1BiN,AiBi)A_i, B_i(1 ≦ A_i ≦ N, 1 ≦ B_i ≦ N, A_i ≠ B_i) が空白を区切りとして与えられる。これは、町 AiA_i と町 BiB_i を結ぶ道があることを表す。
  • 続く行には、0011 のみからなる長さ NN の文字列が与えられる。この ii 文字目が 00 のとき町 ii にはたこ焼き屋がないことを、11 のとき町 ii にはたこ焼き屋があることを表す。
  • 続く QQ 行には、ii 人目の高橋君の移動の始点と目的地を表す整数 si,ti(1siN,1tiN)s_i,t_i(1 ≦ s_i ≦ N, 1 ≦ t_i ≦ N) が与えられる。

出力

出力は QQ 行からなる。

ii 行目には、ii 人目の高橋君が最適に行動したときの移動にかかる時間の最小値を 11 行に出力せよ。

出力の最後には改行を忘れないこと。


入力例1


7 4
1 2
2 3
2 4
4 5
5 6
6 7
0010000
1 5
1 7
6 1
3 3

出力例1


6
9
8
0

最初のクエリでは、町 1,2,4,51,2,4,5 を順に訪れる場合が最善となります。 22 番目のクエリでは、町 1,2,3,2,4,5,6,71,2,3,2,4,5,6,7 と順に訪れ、途中町 33 のたこ焼き屋に寄る場合が最善となります。


入力例2


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

出力例2


6
2

入力例3


12 10
1 2
2 3
2 4
10 12
1 5
3 11
5 6
9 10
5 7
3 9
8 7
000100100010
1 2
1 4
8 3
6 12
12 8
8 12
6 8
8 6
1 12
5 12

出力例3


2
4
6
11
14
9
5
4
9
9