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

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

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

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

Q&A

解決済

1回答

1470閲覧

深さ優先探索を使った全探索について

Naru123

総合スコア19

C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

0グッド

0クリップ

投稿2019/05/03 06:06

(AtCoder Typical Contest 001 のA問題)
で再帰関数を使った解き方をしたのですがどうもうまくいきません。
どうしてもわからなくなったので他の方のコードをみたりしたのですが関数の呼び出しがfor文になっている、配列のゴール地点の座標を使って判定しているといったくらいでコードの違いに大きなところは見られませんでした。
自分が書いたコードは下記の通りです。

C

1#include <stdio.h> 2int h,w,res=0; 3int si,sj,gi,gj; 4char s[500][500]; 5int v[500][500]; 6 7void dfs(int x,int y){ 8 if(x==gi&&y==gj){ 9 res=1; 10 return; 11 } 12 if(x<0||x>=h||y<0||y>=w||s[x][y]=='#')return; 13 if(v[x][y])return; 14 15 v[x][y]=1; 16 17 dfs(x+1,y); 18 dfs(x-1,y); 19 dfs(x,y+1); 20 dfs(x,y-1); 21 return; 22} 23int main(void){ 24 scanf("%d %d",&h,&w); 25 26 for(int i=0;i<h;i++)scanf("%s",s[i]); 27 28 for(int i=0;i<h;i++){ 29 for(int j=0;j<w;j++){ 30 if(s[i][j]=='s'){ 31 si=i; 32 sj=j; 33 } 34 if(s[i][j]=='g'){ 35 gi=i; 36 gj=j; 37 } 38 } 39 } 40 dfs(si,sj); 41 if(res)puts("Yes"); 42 else puts("No"); 43 return 0; 44}

初歩的な質問で大変申し訳ないのですが何かご指摘などあればお願いいたします。

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

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

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

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

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

guest

回答1

0

自己解決

探索済みのマスを記録する二次元配列vの初期化忘れ、bool値を使っていないので必須でした

投稿2019/05/03 06:56

Naru123

総合スコア19

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問