結果
問題 | No.61 リベリオン |
ユーザー |
|
提出日時 | 2024-05-01 09:25:37 |
言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
結果 |
AC
|
実行時間 | 1,034 ms / 5,000 ms |
コード長 | 775 bytes |
コンパイル時間 | 84 ms |
コンパイル使用メモリ | 12,928 KB |
実行使用メモリ | 11,136 KB |
最終ジャッジ日時 | 2024-11-21 12:46:15 |
合計ジャッジ時間 | 2,765 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 4 |
ソースコード
import math Q = int(input()) for _ in range(Q): w, h, d, mx, my, hx, hy, vx, vy = map(int, (input().split())) hit = [[0 for _ in range(w+1)] for _ in range(h+1)] k = math.gcd(abs(vx), abs(vy)) d *= k vx //= k vy //= k x = hx y = hy for _ in range(d): x += vx y += vy while not (0 <= x <= w): if x < 0: x *= -1 else: x = 2 * w - x vx *= -1 while not (0 <= y <= h): if y < 0: y *= -1 else: y = 2 * h - y vy *= -1 if hit[y][x] > 4: break hit[y][x] += 1 if hit[my][mx]: print("Hit") else: print("Miss")