結果
| 問題 |
No.496 ワープクリスタル (給料日前編)
|
| コンテスト | |
| ユーザー |
moririn2528_c
|
| 提出日時 | 2017-03-24 22:47:42 |
| 言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 664 bytes |
| コンパイル時間 | 390 ms |
| コンパイル使用メモリ | 55,292 KB |
| 実行使用メモリ | 5,376 KB |
| 最終ジャッジ日時 | 2024-07-05 22:13:40 |
| 合計ジャッジ時間 | 1,073 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge5 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 2 WA * 2 |
| other | AC * 8 WA * 15 |
ソースコード
#include<iostream>
#define min(a,b) a<b?a:b
using namespace std;
int dp[105][105];
const int MAX=100007;
int main(){
int x,y,n,f;
int cr[55][4];
int i,j,k;
cin>>x>>y>>n>>f;
for(i=0;i<n;i++){
for(j=0;j<3;j++){
cin>>cr[i][j];
}
}
for(i=0;i<105;i++){
for(j=0;j<105;j++){
dp[i][j]=MAX;
}
}
dp[0][0]=0;
for(i=0;i<=x;i++){
for(j=0;j<=y;j++){
if(i!=0)dp[i][j]=min(dp[i][j],dp[i-1][j]+f);
if(j!=0)dp[i][j]=min(dp[i][j],dp[i][j-1]+f);
for(k=0;k<n;k++){
if(i<cr[k][0] || j<cr[k][1] || cr[k][3]==1)continue;
cr[k][3]=1;
dp[i][j]=min(dp[i][j],dp[i-cr[k][0]][j-cr[k][1]]+cr[k][2]);
}
}
}
cout<<dp[x][y]<<endl;
return 0;
}
moririn2528_c