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