結果

問題 No.166 マス埋めゲーム
ユーザー rihito
提出日時 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
権限があれば一括ダウンロードができます

ソースコード

diff #

# サンプル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")
0