結果
| 問題 |
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)