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

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

新規登録して質問してみよう
ただいま回答率
85.46%
C++

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

Q&A

解決済

1回答

501閲覧

DFSが実装できない

sergio

総合スコア10

C++

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

0グッド

0クリップ

投稿2021/07/08 06:35

リンク先の問題をDFSを用いてC++で解いたのですが、
どのような条件に対しても No と出力されてしまいます。
どなたかどこが間違っているのか教えていただけないでしょうか。

C++

1#include <bits/stdc++.h> 2using namespace std; 3#define rep(i, n) for (int i = 0; i < n; i++) 4typedef pair<int, int> P; 5typedef long long ll; 6const int INF = 1001001001; 7const ll INFL = 1e17; 8const int MOD = 1e9 + 7; 9 10vector<vector<int>> seen(500, vector<int>(500, 0)); 11vector<string> c(500); 12int gs; 13int H, W; 14void dfs(int x, int y) 15{ 16 17 if (x <= W - 1 && x >= 0 && y >= 0 && y <= H - 1 && c[x][y] != '#') 18 { 19 if (seen[x][y] == 1) 20 return; 21 seen[x][y] = 1; 22 23 dfs(x + 1, y); 24 dfs(x, y + 1); 25 dfs(x - 1, y); 26 dfs(x, y - 1); 27 } 28 else 29 return; 30} 31 32int main() 33{ 34 int H, W, sx, sy; 35 int gx, gy; 36 cin >> H >> W; 37 rep(i, H) cin >> c[i]; 38 seen.resize(H, vector<int>(W, 0)); 39 rep(i, H) 40 { 41 rep(j, W) 42 { 43 if (c[i][j] == 's') 44 { 45 sx = i; 46 sy = j; 47 } 48 if (c[i][j] == 'g') 49 { 50 gx = i; 51 gy = j; 52 } 53 } 54 } 55 56 dfs(sx, sy); 57 58 if (seen[gx][gy]) 59 cout << "Yes" << endl; 60 else 61 cout << "No" << endl; 62 63 return 0; 64}

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

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

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

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

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

fukasawah

2021/07/08 08:34

たぶんこういった質問は答えを言っても意味が無いので答えは書きません (ヒントを言えばどんなデータを与えても最初のsの位置から1つも辿れておらずseenの中身が全て0のままなのでNoが出る) どこまでが正しく動いているか自分で確認してください。 ・どのように辿ったか画面に出したりしていますか? ・引数は正しく設定されているでしょうか? ・グローバル変数は正しく設定されているでしょうか? ・条件式の判定結果は意図した通りでしょうか?
sergio

2021/07/08 08:55

解決できました。ありがとうございました。
guest

回答1

0

ベストアンサー

まずseenを画面に出力する関数を作成して、各ステップでどこまでseenしたのかを視覚化してみるのはいかがでしょうか?

投稿2021/07/08 08:24

WoodenHamlet

総合スコア306

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問