結果
| 問題 |
No.496 ワープクリスタル (給料日前編)
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2017-04-09 21:00:17 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
AC
|
| 実行時間 | 281 ms / 2,000 ms |
| コード長 | 1,179 bytes |
| コンパイル時間 | 306 ms |
| コンパイル使用メモリ | 82,460 KB |
| 実行使用メモリ | 84,828 KB |
| 最終ジャッジ日時 | 2024-07-18 01:38:33 |
| 合計ジャッジ時間 | 4,664 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 4 |
| other | AC * 23 |
ソースコード
from copy import deepcopy
Gx, Gy, N, F = map( int, input().split() )
X = []
Y = []
C = []
for i in range( N ):
x, y, c = map( int, input().split() )
X.append( x )
Y.append( y )
C.append( c )
if N == 0:
exit( print( F * ( Gx + Gy ) ) )
INF = int( 1e15 )
dp = [ INF for i in range( Gy + 1 ) ]
dp = [ deepcopy( dp ) for i in range( Gx + 1 ) ]
dp = [ deepcopy( dp ) for i in range( N + 1 ) ]
dp[ 0 ][ 0 ][ 0 ] = 0
for i in range( N ):
for j in range( Gx + 1 ):
for k in range( Gy + 1 ):
dp[ i + 1 ][ j ][ k ] = min( dp[ i + 1 ][ j ][ k ], dp[ i ][ j ][ k ] )
if j + X[ i ] <= Gx and k + Y[ i ] <= Gy:
dp[ i + 1 ][ j + X[ i ] ][ k + Y[ i ] ] = min( dp[ i + 1 ][ j + X[ i ] ][ k + Y[ i ] ], dp[ i ][ j ][ k ] + C[ i ] )
if j + 1 <= Gx:
dp[ i ][ j + 1 ][ k ] = min( dp[ i ][ j + 1 ][ k ], dp[ i ][ j ][ k ] + F )
dp[ i + 1 ][ j + 1 ][ k ] = min( dp[ i + 1 ][ j + 1 ][ k ], dp[ i ][ j ][ k ] + F )
if k + 1 <= Gy:
dp[ i ][ j ][ k + 1 ] = min( dp[ i ][ j ][ k + 1 ], dp[ i ][ j ][ k ] + F )
dp[ i + 1 ][ j ][ k + 1 ] = min( dp[ i + 1 ][ j ][ k + 1 ], dp[ i ][ j ][ k ] + F )
print( dp[ N ][ Gx ][ Gy ] )