atcoder#ABC207D. [ABC207D] Congruence Points
[ABC207D] Congruence Points
配点 : 点
問題文
要素数が共に であるような二次元平面上の点の集合 と が与えられます。
に対して以下の操作を 回以上任意の順に好きなだけ繰り返すことで、 と を一致させられるかを判定してください。
- 実数 を定め、 に含まれる全ての点を、原点を中心に時計回りに 度回転させる。
- 実数 を定める。 に含まれる全ての点を、 軸方向に , 軸方向に 移動させる。, の値域に制約はなく、特に正/負/零のいずれになってもよい。
制約
- なら
- なら
- 入力は全て整数
入力
入力は以下の形式で標準入力から与えられる。
出力
問題文中の操作によって と を一致させられるなら Yes
を、一致させられないなら No
を出力せよ。
3
0 0
0 1
1 0
2 0
3 0
3 1
Yes
に含まれる点を赤で、 に含まれる点を緑で塗った場合、与えられる点集合は以下の図の通りになります。
この場合、以下の手順によって を に一致させることができます。
- に含まれる全ての点を、原点を中心に時計回りに 度回転させる。
- に含まれる全ての点を、 軸方向に , 軸方向に 移動させる。
3
1 0
1 1
3 0
-1 0
-1 1
-3 0
No
入力に対応する図は以下の通りです。
と は 軸に対して線対称ですが、問題文中に書かれているような回転操作、移動操作によって と を一致させることはできません。
4
0 0
2 9
10 -2
-6 -7
0 0
2 9
10 -2
-6 -7
Yes
6
10 5
-9 3
1 -5
-6 -5
6 9
-9 0
-7 -10
-10 -5
5 4
9 0
0 -10
-10 -2
Yes