結果
| 問題 | No.103 素因数ゲーム リターンズ | 
| コンテスト | |
| ユーザー |  Igrmi | 
| 提出日時 | 2021-06-20 00:00:25 | 
| 言語 | PyPy3 (7.3.15) | 
| 結果 | 
                                AC
                                 
                             | 
| 実行時間 | 42 ms / 5,000 ms | 
| コード長 | 622 bytes | 
| コンパイル時間 | 174 ms | 
| コンパイル使用メモリ | 82,048 KB | 
| 実行使用メモリ | 58,240 KB | 
| 最終ジャッジ日時 | 2024-06-22 22:21:24 | 
| 合計ジャッジ時間 | 1,884 ms | 
| ジャッジサーバーID (参考情報) | judge4 / judge3 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| sample | AC * 5 | 
| other | AC * 20 | 
ソースコード
Grundy = [0] * 15
for i in range(1, 15):
    S = {Grundy[i - 1]}
    if i > 1: S.add(Grundy[i - 2])
    for j in range(3):
        if j not in S:
            Grundy[i] = j
            break
N = int(input())
M = list(map(int, input().split()))
Num = [i for i in range(101)]
Prime = []
for i in range(2, 101):
    if i != Num[i]: continue
    Prime.append(i)
    for j in range(i + i, 101, i):
        Num[j] = 0
Xor = 0
for m in M:
    for P in Prime:
        Q = 0
        while m % P == 0:
            m //= P
            Q += 1
        Xor ^= Grundy[Q]
    if m != 1: Xor ^= Grundy[1]
print('Alice' if Xor else 'Bob')
            
            
            
        