結果
| 問題 |
No.166 マス埋めゲーム
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2018-11-24 20:50:45 |
| 言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
| 結果 |
AC
|
| 実行時間 | 34 ms / 1,000 ms |
| コード長 | 1,156 bytes |
| コンパイル時間 | 286 ms |
| コンパイル使用メモリ | 12,544 KB |
| 実行使用メモリ | 10,496 KB |
| 最終ジャッジ日時 | 2024-12-24 19:24:41 |
| 合計ジャッジ時間 | 1,770 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 2 |
| other | AC * 20 |
ソースコード
# サンプル1 H=1 W=2 N=2 K=2の場合、
# 1×2列のマス。2番目まで回ったら1番目に戻ると、埋めるマスがないので、1番目の人が負け → "YES"
# サンプル2 H=1 W=2 N=2 K=1の場合
# 1×2列のマス。2番目まで回ったら1番目に戻ると、埋めるマスがないので、1番目の人が負け → "NO"
# サンプルが簡単すぎるので、もうちょっと難しいのを考える。
# 例)20マスで3人でやった時、余りは20÷3で2なので、1,3番目の人は"NO"、2番目の人は"YES""
# 一般化して考える。N番目まで回ったら1番目に戻るということは、きっと余りの問題だと推測しながら……。
# H * W(=S)のマス。SをN番目まで回ると1番目に戻る。S%NがKに一致するかどうかの判定が必要。
# 注意したいのは、S%N == Kとおくと、S%Nは割り切れるとき0となってしまうので、Kと絶対一致せず必ず"NO"になる。
# なので、S%N == K%Nとする必要がある。
H, W, N, K = map(int,input().split())
S = H * W
if S % N == K % N:
print("YES")
else:
print("NO")