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

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

新規登録して質問してみよう
ただいま回答率
85.48%
アルゴリズム

アルゴリズムとは、定められた目的を達成するために、プログラムの理論的な動作を定義するものです。

C++

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

Q&A

解決済

1回答

540閲覧

深さ優先探索を用いて問題を解きたい

eguchinisi

総合スコア4

アルゴリズム

アルゴリズムとは、定められた目的を達成するために、プログラムの理論的な動作を定義するものです。

C++

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

0グッド

0クリップ

投稿2023/01/15 05:31

前提

ここに質問の内容を詳しく書いてください。
(問)
H * Wのマスの盤面がある。その左上端にビショップ(斜めにしか移動できない駒)を置く。そのとき、移動できるマスの数を答えよ。

実現したいこと

この問題を、深さ優先探索を用いて解くことができないかと考え、コードを書きました。しかし、実行すると、 out_of_range: vector というエラーが出てします。
配列の範囲を超えているという内容だと思うのですが、どこが間違いていて、どこを修正すればいいのかわかりません。

ここに実現したいことを箇条書きで書いてください。

  • H * Wの配列を用意する。
  • 0で初期化しておき、ビショップを置くことができれば値を1に変え、カウンターを1増やす
  • 最終的なカウンターの値が、移動できるマスの数にしたい

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

libc++abi: terminating with uncaught exception of type std::out_of_range: vector terminating with uncaught exception of type std::out_of_range: vector (lldb)

該当のソースコード

c++

1#include <iostream> 2#include <vector> 3#include <math.h> 4#include <algorithm> 5using namespace std; 6 7int H, W; 8vector<vector<int>> v(H, vector<int>(W,0)); 9int counter = 0; 10 11 12void dfs(int x, int y) { 13 //現在地 14 v.at(x).at(y) = 1; 15 16 //移動する方向をループ 17 for (int dx = -1; dx < 1; dx++) { 18 for (int dy = -1; dy < 1; dy++) { 19 //移動した位置をnx,nyとする 20 int nx = x + dx, ny = y + dy; 21 if(x + y == nx + ny && 0 <= nx < H && 0 <= ny < W && v.at(nx).at(ny) == 0) { 22 counter++; 23 dfs(nx, ny); 24 } 25 else if(x - y == nx - ny && 0 <= nx < H && 0 <= ny < W && v.at(nx).at(ny) == 0) { 26 counter++; 27 dfs(nx, ny); 28 } 29 } 30 31 } 32} 33 34int main() { 35 cin >> H >> W; 36 v.at(0).at(0) = 1; 37 38 for (int i = 0; i < H; i++) { 39 for (int j = 0; j < W; j++) { 40 if(v.at(i).at(j) == 1){ 41 dfs(i,j); 42 } 43 } 44 } 45 46 cout << counter << endl; 47}

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

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

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

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

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

guest

回答1

0

ベストアンサー

c++

1int H, W; 2vector<vector<int>> v(H, vector<int>(W,0));

H W の初期値は0ですから、v のサイズは 0x0 です。なんの要素にもアクセスできません。
mainH W を入力した後に v のサイズを変更する必要があります。

投稿2023/01/15 06:22

int32_t

総合スコア20882

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

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

eguchinisi

2023/01/15 09:39 編集

ありがとうございます。確かにサイズが0*0になっていました... コードを修正したのですが、やはり同じエラーが出てしまいます... ```lang-c++ #include <iostream> #include <vector> #include <math.h> #include <algorithm> using namespace std; int H, W; vector<vector<int>> v; int counter = 0; void dfs(int x, int y) { //現在地 v.at(x).at(y) = 1; //移動する方向をループ for (int dx = -1; dx < 1; dx++) { for (int dy = -1; dy < 1; dy++) { //移動した位置をnx,nyとする int nx = x + dx, ny = y + dy; if(x + y == nx + ny && 0 <= nx < H && 0 <= ny < W && v.at(nx).at(ny) == 0) { counter++; dfs(nx, ny); } else if(x - y == nx - ny && 0 <= nx < H && 0 <= ny < W && v.at(nx).at(ny) == 0) { counter++; dfs(nx, ny); } } } } int main() { cin >> H >> W; v.resize(H); for (int i = 0; i < H; i++) { v.at(i).resize(W); } v.at(0).at(0) = 1; for (int i = 0; i < H; i++) { for (int j = 0; j < W; j++) { if(v.at(i).at(j) == 1){ dfs(i,j); } } } cout << counter << endl; } ```
int32_t

2023/01/15 10:11

> 0 <= nx < H && 0 <= ny < W C++ でこのような書き方はできません。 0 <= nx && nx < H && 0 <= ny && ny < W と書く必要があります。
eguchinisi

2023/01/16 09:44

ありがとうございます!エラーが解消されました! 欲しい値は出力されませんが、そこは自力で解決してみせます! 本当にありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問