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

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

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

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

Q&A

解決済

2回答

2030閲覧

Cで再帰関数について

hacch

総合スコア15

C

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

0グッド

1クリップ

投稿2020/06/10 07:40

編集2020/06/10 07:49
コード ```C言語で、文字配列 char str[N]; (Nは任意)の中にある特定の文字target_charが含まれているか否かを返す関数 int IsExist(char str[], char target_char, int first_index, int last_index); を以下にしたがって再帰的に定義したいです。 str[first_index] 〜 str[last_index]の中に特定の文字があるかどうかを探す際に、 前半str[first_index] 〜 str[(first_index+last_index)/2]を調べ、無ければ後半のstr[(firs_index+last_index)/2+1]〜str[last_index]を調べる。 もし見つかれば 1 を返し、無ければ 0 を返す。(なのでint型として定義) 再帰定義をするため、終了条件が必要です。これはlast_index = first_index +1 ならばstr[first_index]とstr[last_index]のどちらかにtarget_charがあるかどうかとしたいです。 このプログラムですが、正解してなくてもいいので、少しでも分かる方いらっしゃいましたら教えて欲しいです。。 一応考えたプログラム置いときますが、 もっと端的に<string.h>も使わずにできるはずですが、どうすればもっとコンパクトなソースコードになるんでしょうか ```c #include <stdio.h>#include <string.h>int IsExist(char str[], char target_char, int first_index, int last_index){ int i = first_index; for(; i <= last_index ; ++i){ if( str[i] == target_char ) goto lbl; } if(last_index >first_index || first_index >last_index) return 0; IsExist(str , target_char , first_index , (first_index + last_index) / 2); IsExist(str , target_char , (first_index + last_index) /2 + 1 , last_index); lbl: return 1; } int main(){ char str[64]; char c; printf("検索文字 -->"); scanf("%c", &c); printf("文字列 -->"); scanf("%s", str); if(IsExist(str , c , 0 , strlen(str))){ printf("%c is existing.\n", c); } else { printf("%c is not found.\n", c); } return 0; }

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

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

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

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

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

y_waiwai

2020/06/10 07:43

全体のコードを提示しましょう
ozwk

2020/06/10 07:45

自分でコード書いて「ここがエラーになります」とか「こう動いてほしいのに結果がこうなってしまいます」とかそういう質問をしてください。
episteme

2020/06/10 08:05

↑昇順/降順に並んでないのでバイナリサーチは無理。
ozwk

2020/06/10 08:05

> どうすればもっとコンパクトな それ以前に条件を満たしていない気がするんですが: > 再帰定義をするため、終了条件が必要です。これはlast_index = first_index +1 ならばstr[first_index]とstr[last_index]のどちらかにtarget_charがあるかどうかとしたいです。 これに相当するコード無いですよね?
cateye

2020/06/10 08:12 編集

なんか無茶苦茶なソースですが?・・・インデントきちんとしましょう。 なぜ、gotoがいるのでしょう?・・・そもそも、再帰関数にfor文が出てくるのはおかしい?・・・リニアサーチw ちなみに、str{}がソートされていないのですが?(2分探索はソートされているデータが対象です)
guest

回答2

0

ベストアンサー

C

1int IsExist(const char str[], char target_char, int first_index, int last_index) { 2 if ( first_index == last_index ) return str[first_index] == target_char; 3 int mid_index = (first_index + last_index)/2; 4 return IsExist(str, target_char, first_index, mid_index) || 5 IsExist(str, target_char, mid_index+1, last_index); 6}

投稿2020/06/10 08:03

episteme

総合スコア16612

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

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

0

「正解してなくてもいいので」というのは、学校か何かの出題ですよね?
→ここでは推奨されません。
再帰定義の勉強での出題で、ループ文(forとかwhileとか)を使用してはいけないとの条件があるのでは? こんな検索で再帰を使うのは実用的ではないです。

終了条件は分割できなくなった時、つまり「first_index == last_index」です。
このときはその1文字をチェックして結果を返します。
分割できるとき(2文字以上ある場合)は2つに分割して前半と後半をそれぞれ再帰呼び出しして結果をもらい、どちらかが1ならば1を返します。

投稿2020/06/11 08:51

sage

総合スコア1240

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問