結果
問題 | No.2628 Shrinkage |
ユーザー |
![]() |
提出日時 | 2024-02-17 09:04:47 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 37 ms / 2,000 ms |
コード長 | 881 bytes |
コンパイル時間 | 404 ms |
コンパイル使用メモリ | 82,400 KB |
実行使用メモリ | 54,248 KB |
最終ジャッジ日時 | 2024-09-28 23:34:06 |
合計ジャッジ時間 | 2,255 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 28 |
ソースコード
# 要は三角形の辺を相似に動いてくる、つまり、どうやっても2点間の距離は近くなる # WA出た、距離が短くて平行移動しかできないはず、ベクトル見る # またWA、すべてが1直線上は問題なし、同一点への移動は不可能だd1でが制約上ない T = int(input()) for t in range(T): x1, y1, x2, y2, X1, Y1, X2, Y2 = map(int, input().split()) d = (x1-x2)**2+(y1-y2)**2 D = (X1-X2)**2+(Y1-Y2)**2 (v1x, v1y) = (x2-x1, y2-y1) (v2x, v2y) = (X2-X1, Y2-Y1) #print('(v1x, v1y)', (v1x, v1y), '(v2x, v2y)', (v2x, v2y), D < d, v1y*v2x == v2y*v1x, v1x*v2x >= 0) ans = 'No' if (x1, y1) == (X1, Y1) and (x2, y2) == (X2, Y2): ans = 'Yes' else: if D < d: if v1y*v2x == v2y*v1x: if v1x*v2x >= 0: ans = 'Yes' print(ans)