結果
問題 | No.361 門松ゲーム2 |
ユーザー | i_taku |
提出日時 | 2024-09-03 13:53:03 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 288 ms / 2,000 ms |
コード長 | 404 bytes |
コンパイル時間 | 476 ms |
コンパイル使用メモリ | 82,568 KB |
実行使用メモリ | 76,744 KB |
最終ジャッジ日時 | 2024-09-03 13:53:07 |
合計ジャッジ時間 | 3,323 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 28 |
ソースコード
def dfs(n): if n in dp: return dp[n] S = set(range(n + 1)) for i in range(1, n + 1): for j in range(i + 1, n + 1): k = n - i - j if not j < k or k - i > D: continue S.discard(dfs(i) ^ dfs(j) ^ dfs(k)) dp[n] = min(S) return dp[n] L, D = map(int, input().split()) dp = dict() print('kado' if dfs(L) > 0 else 'matsu')