質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
デバッグ

デバッグはプログラムのバグや欠陥を検知し、開発中のバグを取り除く為のプロセスを指します。

C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

Q&A

解決済

1回答

989閲覧

AtCoder153E問題でWAになる理由が分かりません。

sumachu

総合スコア22

デバッグ

デバッグはプログラムのバグや欠陥を検知し、開発中のバグを取り除く為のプロセスを指します。

C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

0グッド

0クリップ

投稿2020/01/28 14:51

AtCoder153E問題でWAになる理由が分かりません。提出コードは以下の通りです。

C++

1#include <iostream> 2#include <string> 3#include <algorithm> 4#include <vector> 5#include <map> 6#include <bitset> 7#include <stack> 8#include <queue> 9#include <list> 10#include <iomanip> 11#include <numeric> 12using namespace std; 13typedef long long ll; 14const int INF = 1001001001; 15ll mod = 1000000007; 16 17int main() 18{ 19 int h, n; 20 cin >> h >> n; 21 vector<int> a(n), b(n); 22 for (int i = 0; i < n; i++) cin >> a[i] >> b[i]; 23 24 vector<vector<int>> mp(n, vector<int>(h + 1, INF)); 25 for (int i = 0; i < n; i++) mp[i][0] = 0; 26 27 for (int i = 0; i < n; i++) { 28 for (int j = 0; j < h; j++) { 29 int nj = min(j + a[i], h); 30 if (0 < i) mp[i][nj] = min(mp[i][nj], mp[i - 1][nj]); 31 if (mp[i][j] != INF) mp[i][nj] = min(mp[i][nj], mp[i][j] + b[i]); 32 } 33 } 34 cout << mp[n - 1][h] << endl; 35} 36

テストケースのmax_06がWAになります。入力例をデバッグで、ウォッチしましたが、自分なりに個数制限なしナップサックDPのアルゴリズムは組めていると思っています。現時点ではatcoder_testcasesにテストケースはアップされていません。上のコードのどこが間違っているのでしょうか?

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

C++

1 if (0 < i) mp[i][nj] = min(mp[i][nj], mp[i - 1][nj]);

この行の添え字が間違いでしょう。

Text

110 2 21 1 39 3

例えばこんなテストケースの場合、明らかに答えは4ですが6が出力されます。
あとはデバッグすればわかると思います。

投稿2020/01/28 15:33

yudedako67

総合スコア2047

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

sumachu

2020/01/28 17:45

テストケースありがとうございます。とても参考になりました。挙動は理解しました。コードはスマートではありませんが、以下のように変更したらACできました。 // i番目の魔法を使う場合を調査 if (0 < i) mp[i][j] = min(mp[i][j], mp[i - 1][j]); // i行目の情報を更新 if (mp[i][j] != INF) mp[i][nj] = min(mp[i][nj], mp[i][j] + b[i]); // i番目の魔法を使わない場合を調査 if (0 < i) mp[i][nj] = min(mp[i][nj], mp[i - 1][nj]);
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問