結果
| 問題 |
No.496 ワープクリスタル (給料日前編)
|
| コンテスト | |
| ユーザー |
H20
|
| 提出日時 | 2021-01-18 11:11:15 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
AC
|
| 実行時間 | 76 ms / 2,000 ms |
| コード長 | 651 bytes |
| コンパイル時間 | 249 ms |
| コンパイル使用メモリ | 82,048 KB |
| 実行使用メモリ | 75,776 KB |
| 最終ジャッジ日時 | 2024-11-30 22:43:05 |
| 合計ジャッジ時間 | 2,609 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 4 |
| other | AC * 23 |
ソースコード
GX,GY,N,F = map(int,input().split())
DP = [[0] * (GX+1) for i in range(GY+1)]
for i in range(N):
tx,ty,tc = map(int,input().split())
for y in reversed(range(GY+1)):
for x in reversed(range(GX+1)):
if DP[y][x]>0 and y+ty<=GY and x+tx<=GX:
DP[y+ty][x+tx] = min(DP[y+ty][x+tx],DP[y][x]+tc)
if DP[y+ty][x+tx]==0:
DP[y+ty][x+tx]=DP[y][x]+tc
DP[ty][tx] = min(DP[ty][tx],tc)
if DP[ty][tx]==0:
DP[ty][tx] = tc
ans = (GX+GY)*F
for y in range(GY+1):
for x in range(GX+1):
if DP[y][x] > 0:
ans = min(ans,((GY+GX-y-x))*F+DP[y][x])
print(ans)
H20