結果

問題 No.496 ワープクリスタル (給料日前編)
ユーザー RonlynesRonlynes
提出日時 2017-08-23 14:53:24
言語 C++11
(gcc 11.4.0)
結果
WA  
実行時間 -
コード長 2,026 bytes
コンパイル時間 503 ms
コンパイル使用メモリ 57,992 KB
実行使用メモリ 6,948 KB
最終ジャッジ日時 2024-04-23 13:09:09
合計ジャッジ時間 1,565 ms
ジャッジサーバーID
(参考情報)
judge1 / judge3
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 WA -
testcase_01 WA -
testcase_02 WA -
testcase_03 WA -
testcase_04 WA -
testcase_05 WA -
testcase_06 WA -
testcase_07 WA -
testcase_08 WA -
testcase_09 WA -
testcase_10 WA -
testcase_11 WA -
testcase_12 WA -
testcase_13 WA -
testcase_14 WA -
testcase_15 WA -
testcase_16 WA -
testcase_17 WA -
testcase_18 WA -
testcase_19 WA -
testcase_20 WA -
testcase_21 WA -
testcase_22 WA -
testcase_23 WA -
testcase_24 WA -
testcase_25 WA -
testcase_26 WA -
権限があれば一括ダウンロードができます
コンパイルメッセージ
main.cpp: In function ‘int main()’:
main.cpp:63:34: warning: ‘mi_k’ may be used uninitialized in this function [-Wmaybe-uninitialized]
   63 |                 used[i][j][mi_k] = false;
      |                 ~~~~~~~~~~~~~~~~~^~~~~~~

ソースコード

diff #

#include <iostream>
using namespace std;

const int inf = 1e9;
int main(void){
    int gx, gy, n, f, x[101],y[101],c[101];
    cin >> gx >> gy >> n >> f;
    for(int i=0; i<n; i++){
        cin >> x[i] >> y[i] >> c[i];
    }
    int dp[101][101];
    dp[0][0] = 0;
    
    bool used[101][101][50];

    for(int i=0; i<=gy; i++){
        for(int j=0; j<=gx; j++){
            for(int k=0; k<n; k++){
                used[i][j][k] = true;
            }
        }
    }

    for(int j=1;j<=gx;j++){
        dp[0][j] = dp[0][j-1]+f;
        for(int k=0;k<n;k++){
          int px = j - x[k], py = 0 - y[k];
          if(px >= 0 && px <= gx && py >= 0 && py <= gy){
            dp[0][j] = min(dp[py][px]+c[k],dp[0][j]);
          }
        }
    }

    for(int i=1; i<=gy; i++){
        dp[i][0] = dp[i-1][0]+f;
        for(int k=0; k<n; k++){
          int px = 0 - x[k], py = i - y[k];
          if(px >= 0 && px <= gx && py >= 0 && py <= gy){
            dp[i][0] = min(dp[py][px]+c[k], dp[i][0]);
          }
        }
    }
    
    for(int i=1; i<=gy; i++){
        for(int j=1; j<=gx; j++){
            dp[i][j] = min(dp[i-1][j]+f, dp[i][j-1]+f);
            int mi=inf, mi_k;
            for(int k=0;k<n;k++){
                int px = j - x[k], py = i - y[k];
                if(px >= 0 && px <= gx && py >= 0 && py <= gy && used[py][px][k] == true){
                    if(dp[py][px]+c[k] < dp[i][j]){
                        mi = min(dp[py][px]+c[k], mi);
                        mi_k = k;
                    }
                    
                }
            }
            dp[i][j] = min(mi,dp[i][j]);
            for(int k=0;k<n;k++){
                used[i][j][k] = used[i-y[mi_k]][j-x[mi_k]][k];
            }
            if(mi != inf){
                used[i][j][mi_k] = false;
            }
        }
    }
    cout << dp[gy][gx] << endl;
    for(int i=0; i<=gy; i++){
        for(int j=0; j<=gx; j++){
            cout << dp[i][j] << " ";
        }
        cout << endl;
    }
    cout << endl;
    return 0;
}
0