結果
問題 |
No.103 素因数ゲーム リターンズ
|
ユーザー |
|
提出日時 | 2024-09-03 13:28:40 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 103 ms / 5,000 ms |
コード長 | 754 bytes |
コンパイル時間 | 354 ms |
コンパイル使用メモリ | 82,084 KB |
実行使用メモリ | 79,908 KB |
最終ジャッジ日時 | 2024-09-03 13:28:45 |
合計ジャッジ時間 | 4,064 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 5 |
other | AC * 20 |
ソースコード
def get_primes(size): is_prime = [True] * (size + 1) is_prime[0] = is_prime[1] = False primes = [] for i in range(size + 1): if not is_prime[i]: continue primes.append(i) for j in range(i + i, size + 1, i): is_prime[j] = False return primes N = int(input()) M = list(map(int, input().split())) MAX = 10_000 S = [set(range(4)) for _ in range(MAX + 1)] dp = [0] * (MAX + 1) primes = get_primes(MAX) for n in range(1, MAX + 1): dp[n] = min(S[n]) for p in primes: if n * p > MAX: break S[n * p].discard(dp[n]) if n * p * p <= MAX: S[n * p * p].discard(dp[n]) xor = 0 for m in M: xor ^= dp[m] print('Alice' if xor > 0 else 'Bob')