結果
問題 |
No.458 異なる素数の和
|
ユーザー |
![]() |
提出日時 | 2017-03-28 21:49:18 |
言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
結果 |
TLE
|
実行時間 | - |
コード長 | 459 bytes |
コンパイル時間 | 532 ms |
コンパイル使用メモリ | 12,672 KB |
実行使用メモリ | 16,256 KB |
最終ジャッジ日時 | 2024-07-06 13:30:37 |
合計ジャッジ時間 | 3,704 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | -- * 3 |
other | AC * 1 TLE * 1 -- * 26 |
ソースコード
N = int(input()) is_prime = [True for i in range(N+1)] is_prime[0] = is_prime[1] = False for i in range(2,N+1): if not is_prime[i]: continue for j in range(i*2,N+1,i): is_prime[j] = False prime = [i for i in range(2,N+1) if is_prime[i]] P = len(prime) dp = [0 for i in range(N+1)] dp[0] = 1 for i in range(P): for j in range(N,-1,-1): if dp[j] and j+prime[i] <= N: dp[j+prime[i]] = max(dp[j+prime[i]],dp[j]+1) print(dp[N]-1 if dp[N] != 0 else -1)