結果
| 問題 | No.7 プライムナンバーゲーム |
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2026-04-16 11:31:46 |
| 言語 | Python3 (3.14.3 + numpy 2.4.4 + scipy 1.17.1) |
| 結果 |
AC
|
| 実行時間 | 390 ms / 5,000 ms |
| コード長 | 838 bytes |
| 記録 | |
| コンパイル時間 | 784 ms |
| コンパイル使用メモリ | 20,696 KB |
| 実行使用メモリ | 15,360 KB |
| 最終ジャッジ日時 | 2026-04-16 11:31:56 |
| 合計ジャッジ時間 | 5,010 ms |
|
ジャッジサーバーID (参考情報) |
judge2_0 / judge3_0 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 17 |
ソースコード
def prime_number(N):
if N < 2:
return False
if N % 2 == 0:
return N == 2
i = 3
while i * i <= N:
if N % i == 0:
return False
i += 2
return True
def generate_primes(limit):
primes = []
for i in range(2, limit + 1):
if prime_number(i):
primes.append(i)
return primes
def can_first_player_win(N):
primes = generate_primes(N)
dp = [False] * (N + 1)
for i in range(2, N + 1):
for p in primes:
if p > i:
break
next_value = i - p
if next_value >= 2 and not dp[next_value]:
dp[i] = True
break
return dp[N]
def main():
N = int(input())
print("Win" if can_first_player_win(N) else "Lose")
if __name__ == "__main__":
main()