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

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

新規登録して質問してみよう
ただいま回答率
85.35%
コードレビュー

コードレビューは、ソフトウェア開発の一工程で、 ソースコードの検査を行い、開発工程で見過ごされた誤りを検出する事で、 ソフトウェア品質を高めるためのものです。

C++

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

Q&A

解決済

1回答

1765閲覧

AtCoder ABC166-B

Ryuking885

総合スコア3

コードレビュー

コードレビューは、ソフトウェア開発の一工程で、 ソースコードの検査を行い、開発工程で見過ごされた誤りを検出する事で、 ソフトウェア品質を高めるためのものです。

C++

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

0グッド

0クリップ

投稿2020/05/04 08:35

AtCoder ABC166-B

https://atcoder.jp/contests/abc166/tasks/abc166_b
イメージ説明
イメージ説明

この問題でWAとREというエラーメッセージが出ました。
解決法を教えてください。よろしくお願いします。

発生している問題・エラーメッセージ

イメージ説明

ソースコード

C++

1#include <bits/stdc++.h> 2using namespace std; 3typedef long long ll; 4#define rep(i, n) for (int i = 0; i < (int)(n); i++) 5const long long INF = 1LL << 60; 6 7int main() 8{ 9 int N, K; 10 cin >> N >> K; 11 vector<int> d(K); 12 vector<vector<int>> A(K, vector<int>(K)); 13 rep(i,K) 14 { 15 cin >> d[i]; 16 rep(j, d[i]) 17 { 18 cin >> A[i][j]; 19 } 20 } 21 vector<bool> have(N,false); 22 rep(i,K) rep(j,K) 23 { 24 have[A[i][j]] = true; 25 } 26 27 int res = 0; 28 rep(i,N) 29 { 30 if(!have[i]) res++; 31 } 32 cout << res << endl; 33} 34

考え

まずboolの配列haveをfalseで初期化しました。
次に配列Aに登場する数字番目の要素をtrueにしました。
最後にfalseの数を数え上げて、答えとしました。

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

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

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

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

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

guest

回答1

0

ベストアンサー

vector<vector<int>> A(K, vector<int>(K));
が原因で、2番目の K は本来であれば、d_iである必要があり、配列外参照が起こっています。

簡単な解決方法としては、
vector<vector<int>> A(K, vector<int>(N));
にすれば良いと思います。

また、have[A[i][j]] = true;も配列外参照が起こるとおもうので、
have[A[i][j] - 1] = true;にする必要があります。

投稿2020/05/04 08:40

編集2020/05/04 08:42
minaminao

総合スコア249

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

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

yuki23

2020/05/04 08:45

A[i][j] - 1 にすると A[i][j] == 0 のときに配列外参照してしまうので、Aを固定長にするのはダメです
minaminao

2020/05/04 08:47

> A[i][j] - 1 にすると A[i][j] == 0 のときに配列外参照してしまう A[i][j] の制約は 1~N じゃないですか?
minaminao

2020/05/04 08:48

A[i][j] == N のときに、have[A[i][j]] が have[N] になって配列外参照するように見えます…
yuki23

2020/05/04 08:49

入力値の範囲はそうですが、d[i] <= N は毎回異なります。入力されていないところは初期値の0になってしまいます。
minaminao

2020/05/04 08:50

加えて、rep(i,K) rep(j,K) を rep(i,K) rep(j,d[i]) にしてください
Ryuking885

2020/05/04 09:05

探索範囲など、もろもろ間違えていましたが、解決しました。 ありがとうございました。 #include <bits/stdc++.h> using namespace std; typedef long long ll; #define rep(i, n) for (int i = 0; i < (int)(n); i++) const long long INF = 1LL << 60; int main() { int N, K; cin >> N >> K; vector<int> d(K); vector<vector<int>> A(K, vector<int>(N)); rep(i,K) { cin >> d[i]; rep(j, d[i]) { cin >> A[i][j]; } } vector<bool> have(N,false); rep(i,K) rep(j, d[i]) { have[A[i][j]] = true; } int res = 0; for(int i = 1; i <= N; i++) { if(!have[i]) res++; } cout << res << endl; }
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問