結果
問題 |
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")