JAG (Japan Aerospace-exploration Group) の小惑星探査機群まわりこみやが 2019 年に地球を飛び立ってから 10 年,いよいよ目標の小惑星帯 ICPC-2020 へ接近する日が近づいてきた.この探査プロジェクトにおいては,複数の探査機がそれぞれ異なる小惑星からサンプルを採取することになっている.ところが,この 3 日前になって JAG の宇宙観測部門がある重大な見落としに気がついた.彼らの報告によると,まわりこみやの現在地から ICPC-2020 の間にはいくつもの障害物が存在し,このままの軌道ではまわりこみやは衝突してしまうかもしれないらしい.
すぐさま緊急会議が行われ,エンジン噴射で機体を制御して障害物を回避することになった.必要な制御プログラムの実装は JAG の技術者であり競技プログラマーでもあるあなたが担当することも決まった.あなたがこれから書くプログラムの仕様は競技プログラミング風に言えば次のようになるだろう.
Q 機のまわりこみやの機体とそれぞれが目標とする小惑星の位置が xy-平面上の点として与えられる(宇宙工学的要請によりまわりこみやはこの平面上しか動けない.まわりこみやと小惑星は障害物と比べて十分小さく,大きさは無視できる).また,この平面と交差する障害物の情報も複数の多角形として与えられる.まわりこみやはこの平面上でいくつかの線分からなる折れ線状の経路に沿って移動することができ,これによって障害物にぶつかることなく ICPC-2020 の座標に到達することが目標である(まわりこみやが多角形の辺上に存在することはできる). この宙域には弱い重力が作用しており,線分に沿って移動する際に y 座標が増加しないなら噴射をする必要はないが,y 座標が増加するときは y 座標 1 あたり 1 ジュールの割合でエネルギーを使って噴射する必要がある.探査機のエネルギーを使いすぎると帰還が困難になってしまうので,消費エネルギーはできるだけ少なくしたい. それぞれの機体について,目標の小惑星に到達するのに必要な最小のエネルギーを求めよ.
入力は最大 50 データセットからなり,各データセットは次の形式で表される.
N Q
v1
x1,1 y1,1
...
x1,v1 y1,v1
v2
x2,1 y2,1
...
x2,v2 y2,v2
...
vN
xN,1 yN,1
...
xN,vN yN,vN
sx1 sy1 gx1 gy1
...
sxQ syQ gxQ gyQ
最初の行には障害物を表す多角形の個数 N (1 ≤ N ≤ 10) と探査機の個数 Q (1 ≤ Q ≤ 1000) がこの順で与えられている.この次に N 回にわたって多角形の情報が与えられる.それぞれの多角形は次の形式で表される.
i 個目の多角形の頂点数 vi (3 ≤ vi ≤ 100) が 1 行目に与えられる.続く vi 行に,1 行に 1 頂点ずつ多角形を構成する頂点の座標が与えられる.これらの行には x 座標と y 座標がこの順で与えられている.i 個目の多角形は,ここに登場する頂点を登場する順に辺で結び,最後の頂点と最初の頂点を辺で結ぶと得られる.この多角形は自己交差を持たない単純な多角形であることが保証されている.
多角形の情報に続いて Q 行に渡って探査機と小惑星の情報が与えられる.各行には探査機の座標 (sxi, syi) と目標とする小惑星の座標 (gxi, gyi) がこの順で与えられる.
各データセットにおいて与えられる座標は全て整数であり,x 座標と y 座標の絶対値はともに 1000 を超えない.また,どの 2 つの多角形の面(内部と境界を合わせた点の集合)同士の共通部分も空であること,始点と終点はすべての多角形の外部の共通部分に存在することが保証されている.
入力の末尾は空白で区切られた 2 つの 0 で表される.
各データセットに対し Q 行を出力せよ.Q 行のうちの i 行目には i 番目の探査機に必要な最小のエネルギーを出力せよ.結果は 10−6 以上の誤差を含んではいけない.
1 1 4 1 2 3 2 3 -1 1 -1 0 0 5 0 2 1 4 0 -1 -1 -4 0 -2 1 -4 4 0 1 -1 4 0 2 1 4 0 -3 0 3 4 3 6 0 2 3 2 2 0 3 -2 0 -2 1 0 6 3 0 4 -2 5 -2 4 0 5 2 4 2 7 6 2 7 2 9 1 7 0 7 -2 6 -2 5 0 6 9 0 10 -2 11 -2 10 0 11 2 10 2 0 -1 11 1 11 1 0 -1 11 1 11 -1 0 0
1.000000000000 8.000000000000 3.000000000000 1.000000000000 0