結果
| 問題 | No.153 石の山 |
| コンテスト | |
| ユーザー |
nisizawa
|
| 提出日時 | 2017-12-12 11:13:48 |
| 言語 | Python3 (3.14.3 + numpy 2.4.4 + scipy 1.17.1) |
| 結果 |
AC
|
| 実行時間 | 94 ms / 5,000 ms |
| コード長 | 492 bytes |
| 記録 | |
| コンパイル時間 | 621 ms |
| コンパイル使用メモリ | 20,568 KB |
| 実行使用メモリ | 15,360 KB |
| 最終ジャッジ日時 | 2026-05-24 23:05:34 |
| 合計ジャッジ時間 | 4,822 ms |
|
ジャッジサーバーID (参考情報) |
judge2_0 / judge3_0 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 4 |
| other | AC * 27 |
ソースコード
import math
n = int(input())
grundy_ls = [-1] * (n + 1)
grundy_ls[1] = 0
def grundy(n):
if grundy_ls[n] >= 0:
return grundy_ls[n]
g_set = set()
g_set.add(grundy(n // 2) ^ grundy(math.ceil(n / 2)))
if n >= 3:
g_set.add(grundy(n // 3) ^ grundy(round(n / 3)) ^ grundy(math.ceil(n / 3)))
for i in range(n):
if not i in g_set:
grundy_ls[n] = i
return i
gn = grundy(n)
if gn == 0:
print('B')
else:
print('A')
nisizawa