結果
| 問題 | No.1037 exhausted |
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2020-05-04 16:35:31 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
AC
|
| 実行時間 | 222 ms / 2,000 ms |
| コード長 | 600 bytes |
| コンパイル時間 | 192 ms |
| コンパイル使用メモリ | 81,908 KB |
| 実行使用メモリ | 105,784 KB |
| 最終ジャッジ日時 | 2024-06-24 14:55:59 |
| 合計ジャッジ時間 | 3,713 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 23 |
ソースコード
n,v,l=map(int,input().split())
arr=[list(map(int,input().split())) for _ in range(n)]
n+=1
arr.append([l,0,0])
dp=[[10**18]*(v+1) for _ in range(n+1)]
dp[0][v]=0
now=0
for i in range(n):
dist=arr[i][0]-now
gas=arr[i][1]
cost=arr[i][2]
flag=False
for j in range(v-dist,-1,-1):
dp[i+1][j]=dp[i][j+dist]
if dp[i+1][j]!=10**18:
flag=True
if flag==False:
print(-1)
break
else:
for j in range(v,-1,-1):
dp[i+1][min(v,j+gas)]=min(dp[i+1][min(v,j+gas)],dp[i+1][j]+cost)
now=arr[i][0]
else:
print(min(dp[-1]))