正義のヒーロー「スパイダー人」は、腕からロープを出してビルからビルへ飛び移ることができます。しかし、ロープが短いので自分からの距離が 50 以下のビルにしか移動できません。それより遠くのビルに移動するには、一旦別のビルに飛び移らなくてはなりません。
ビルの数 n、n 個のビルの情報、スパイダー人の移動開始位置及び目的地を入力とし、その移動の最短経路を出力するプログラムを作成してください。どのようにビルを経由しても目標のビルに移動できない場合は NA と出力してください。各ビルは点として扱い、最短距離で移動するビルの経由方法が2つ以上存在することはないものとします。
複数のデータセットの並びが入力として与えられます。入力の終わりはゼロひとつの行で示されます。 各データセットは以下の形式で与えられます。
n b1 x1 y1 b2 x2 y2 : bn xn yn m s1 g1 s2 g2 : sm gm
1行目にビルの数 n (1 ≤ n ≤ 100)、続く n 行に i 番目のビルのビル番号 bi (1 ≤ bi ≤ n)、そのビルのx座標とy座標を表す整数 xi, yi (-1000 ≤ xi, yi ≤ 1000) が空白区切りで与えられます。
続く行に移動情報の個数 m (1 ≤ m ≤ 100)、続く m 行にi 番目の移動情報が与えられます。各移動情報として、移動を開始するビルの番号 si と目的地ビルの番号 gi が空白区切りで与えられます。
データセットの数は 10 を超えません。
入力データセットごとに次の形式で出力します。
i 行目に i 番目の移動情報に対する経路または NA を1行に出力します。各経路は以下の形式で出力します。
si bri1 bri2 ... gi
brij は i 番目の移動情報における、j 番目に経由するビルの番号を表します。
4 1 0 0 2 30 0 3 60 40 4 0 60 2 1 3 1 4 22 1 0 0 2 150 40 3 30 20 4 180 150 5 40 80 6 130 130 7 72 28 8 172 118 9 50 50 10 160 82 11 90 105 12 144 131 13 130 64 14 80 140 15 38 117 16 190 90 17 60 100 18 100 70 19 130 100 20 71 69 21 200 110 22 120 150 1 1 22 0
1 2 3 NA 1 3 9 20 11 6 22