結果
問題 | No.1861 Required Number |
ユーザー |
|
提出日時 | 2022-03-05 12:52:33 |
言語 | PyPy3 (7.3.15) |
結果 |
MLE
(最新)
AC
(最初)
|
実行時間 | - |
コード長 | 879 bytes |
コンパイル時間 | 164 ms |
コンパイル使用メモリ | 82,284 KB |
実行使用メモリ | 902,744 KB |
最終ジャッジ日時 | 2024-07-19 16:35:23 |
合計ジャッジ時間 | 24,181 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 1 MLE * 2 |
other | AC * 42 TLE * 3 MLE * 1 |
ソースコード
from sys import exit n, k = map(int,input().split()) A = list(map(int,input().split())) lDP=[[False for _ in range(k+1)] for _ in range(n+1)] rDP=[[False for _ in range(k+1)] for _ in range(n+1)] lDP[0][0]=True for i in range(n): for j in range(k+1): lDP[i+1][j]=lDP[i][j] x=A[i] for j in range(k+1): if x+j>k: break if lDP[i][j]: lDP[i+1][j+x]=True if not lDP[n][k]: print(-1) exit() rDP[n][0]=True for i in range(n,0,-1): for j in range(k+1): rDP[i-1][j]=rDP[i][j] x=A[i-1] for j in range(k+1): if x+j>k: break if rDP[i][j]: rDP[i-1][j+x]=True ans=0 for i in range(n): use_flag = True for j in range(k+1): if lDP[i][j] and rDP[i+1][k-j]: use_flag = False break if use_flag: ans+=1 print(ans)