結果
問題 | No.7 プライムナンバーゲーム |
ユーザー |
|
提出日時 | 2023-01-04 09:37:09 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 111 ms / 5,000 ms |
コード長 | 875 bytes |
コンパイル時間 | 234 ms |
コンパイル使用メモリ | 81,920 KB |
実行使用メモリ | 62,464 KB |
最終ジャッジ日時 | 2024-11-27 12:16:50 |
合計ジャッジ時間 | 2,161 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 17 |
ソースコード
import math def sieve_of_eratosthenes(n): prime = [True for i in range(n+1)] prime[0] = False prime[1] = False sqrt_n = math.ceil(math.sqrt(n)) for i in range(2, sqrt_n): if prime[i]: for j in range(2*i, n+1, i): prime[j] = False return prime prime = sieve_of_eratosthenes(10000) prm = [] for p in range(10001): if prime[p]: prm.append(p) N = int(input()) dp = [0] * (N + 1) for i in range(N + 1): dp[i] = True dp[2] = False dp[3] = False if N <= 10: print("Win") exit() for i in range(11, N + 1): winflag = False for p in prm: if p >= i: break elif dp[i - p] == False: winflag = True # if i == N: # print(i, p, dp[i - p]) break dp[i] = winflag print("Win" if dp[i] else "Lose")