結果
問題 |
No.496 ワープクリスタル (給料日前編)
|
ユーザー |
![]() |
提出日時 | 2022-09-14 12:08:44 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 178 ms / 2,000 ms |
コード長 | 953 bytes |
コンパイル時間 | 414 ms |
コンパイル使用メモリ | 82,136 KB |
実行使用メモリ | 82,252 KB |
最終ジャッジ日時 | 2024-12-14 23:16:32 |
合計ジャッジ時間 | 3,961 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 23 |
ソースコード
gx,gy,n,f=map(int,input().split()) wa=[[0,0,0]]+[list(map(int,input().split())) for i in range(n)] inf=10**8 dp=[[[inf]*(gy+1) for i in range(gx+1)] for i in range(n+2)] dp[0][0][0] = 0 for w in range(n+2): for i in range(gx+1): for j in range(gy+1): if dp[w][i][j] == inf: continue if w+1 < n+2: dp[w+1][i][j] = min(dp[w+1][i][j],dp[w][i][j]) if i + 1 <= gx: dp[w][i+1][j] = min(dp[w][i+1][j],dp[w][i][j]+f) if j + 1 <= gy: dp[w][i][j+1] = min(dp[w][i][j+1],dp[w][i][j]+f) if w+1 < n + 2: x,y,c=wa[w][0],wa[w][1],wa[w][2] if i <= i+x <=gx and j <= j+y <=gy: dp[w+1][i+x][j+y] = min(dp[w+1][i+x][j+y],dp[w][i][j] + c) ans=10**10 # for i in range(n+2): # ans=min(ans,dp[i][gx][gy]) # print(ans) print(dp[n+1][gx][gy])