結果

問題 No.166 マス埋めゲーム
ユーザー rihitorihito
提出日時 2018-11-24 20:50:45
言語 Python3
(3.12.2 + numpy 1.26.4 + scipy 1.12.0)
結果
AC  
実行時間 33 ms / 1,000 ms
コード長 1,156 bytes
コンパイル時間 182 ms
コンパイル使用メモリ 12,544 KB
実行使用メモリ 10,624 KB
最終ジャッジ日時 2024-06-07 00:07:36
合計ジャッジ時間 1,917 ms
ジャッジサーバーID
(参考情報)
judge1 / judge3
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 32 ms
10,368 KB
testcase_01 AC 29 ms
10,368 KB
testcase_02 AC 29 ms
10,368 KB
testcase_03 AC 29 ms
10,496 KB
testcase_04 AC 29 ms
10,496 KB
testcase_05 AC 29 ms
10,496 KB
testcase_06 AC 28 ms
10,496 KB
testcase_07 AC 28 ms
10,496 KB
testcase_08 AC 28 ms
10,368 KB
testcase_09 AC 30 ms
10,496 KB
testcase_10 AC 33 ms
10,368 KB
testcase_11 AC 30 ms
10,624 KB
testcase_12 AC 30 ms
10,496 KB
testcase_13 AC 29 ms
10,496 KB
testcase_14 AC 31 ms
10,496 KB
testcase_15 AC 29 ms
10,368 KB
testcase_16 AC 30 ms
10,496 KB
testcase_17 AC 30 ms
10,496 KB
testcase_18 AC 29 ms
10,496 KB
testcase_19 AC 31 ms
10,496 KB
testcase_20 AC 29 ms
10,496 KB
testcase_21 AC 30 ms
10,368 KB
権限があれば一括ダウンロードができます

ソースコード

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