文字列から文字列を探索

フォーラム(掲示板)ルール
フォーラム(掲示板)ルールはこちら  ※コードを貼り付ける場合は [code][/code] で囲って下さい。詳しくはこちら
けろけろ

文字列から文字列を探索

#1

投稿記事 by けろけろ » 7年前

コード:

#include <stdio.h>
int main(void) {
	int a, b, c, x, i;
	char moji[]="ABCDEFG HIJKLMN OPQRSTU VWXYZ";
	char retsu[10];

	printf("%sy\n",moji);
	printf("探索する文字列(10文字以内)を入力:");
	scanf("%s", retsu);

	


	return 0;
}



打ち込んだ文字列が
最初の文字列にあるかどうかを探索するプログラムは
この先どうしたらいいのですか?

アバター
みけCAT
記事: 6734
登録日時: 13年前
住所: 千葉県
連絡を取る:

Re: 文字列から文字列を探索

#2

投稿記事 by みけCAT » 7年前

strstrかなんかを使って実装したらいいと思いますが、まず「最初の文字列」とはなんですか?
オフトピック
メッセージには「10文字以内」とありますが、10文字(10バイト)入力すると最後のヌル文字が範囲外に書き込まれ、未定義動作を起こすので、
このプログラムには10バイト以上(10バイトを含みます、念のため)の文字列を入力してはいけません。
(これは文字列として入力するデータが9バイトを超えるとダメということです。例えば9バイト+改行文字の合計10バイト、というのはOK)
複雑な問題?マシンの性能を上げてOpenMPで殴ればいい!(死亡フラグ)

けろけろ

Re: 文字列から文字列を探索

#3

投稿記事 by けろけろ » 7年前

みけCAT さんが書きました:strstrかなんかを使って実装したらいいと思いますが、まず「最初の文字列」とはなんですか?
オフトピック
メッセージには「10文字以内」とありますが、10文字(10バイト)入力すると最後のヌル文字が範囲外に書き込まれ、未定義動作を起こすので、
このプログラムには10バイト以上(10バイトを含みます、念のため)の文字列を入力してはいけません。
(これは文字列として入力するデータが9バイトを超えるとダメということです。例えば9バイト+改行文字の合計10バイト、というのはOK)

税所の文字列というのは、
ABCD~
とかのやつです!

あと、strstrを使わずにやる方法を知りたいです!

アバター
みけCAT
記事: 6734
登録日時: 13年前
住所: 千葉県
連絡を取る:

Re: 文字列から文字列を探索

#4

投稿記事 by みけCAT » 7年前

けろけろ さんが書きました:あと、strstrを使わずにやる方法を知りたいです!
Boyer Moore法かなんかを使って実装すればいいでしょう。
複雑な問題?マシンの性能を上げてOpenMPで殴ればいい!(死亡フラグ)

けろけろ

Re: 文字列から文字列を探索

#5

投稿記事 by けろけろ » 7年前

みけCAT さんが書きました:
けろけろ さんが書きました:あと、strstrを使わずにやる方法を知りたいです!
Boyer Moore法かなんかを使って実装すればいいでしょう。

探索のアルゴリズムや、繰り返し、分岐をつかってできませんか?

アバター
みけCAT
記事: 6734
登録日時: 13年前
住所: 千葉県
連絡を取る:

Re: 文字列から文字列を探索

#6

投稿記事 by みけCAT » 7年前

けろけろ さんが書きました:探索のアルゴリズムや、繰り返し、分岐をつかってできませんか?
Boyer Moore法は探索のアルゴリズムの一種です。
繰り返しや分岐も使います。
従って、できるはずです。
複雑な問題?マシンの性能を上げてOpenMPで殴ればいい!(死亡フラグ)

けろけろ

Re: 文字列から文字列を探索

#7

投稿記事 by けろけろ » 7年前

みけCAT さんが書きました:
けろけろ さんが書きました:探索のアルゴリズムや、繰り返し、分岐をつかってできませんか?
Boyer Moore法は探索のアルゴリズムの一種です。
繰り返しや分岐も使います。
従って、できるはずです。

まだそれは学習していなくて・・・
リニアサーチや、番兵や、バイナリサーチを使いたいです

アバター
usao
記事: 1887
登録日時: 11年前

Re: 文字列から文字列を探索

#8

投稿記事 by usao » 7年前

何に困っているのかがわかりません.


例えば,
「長さ5文字の文字列 "ABCDE" の中に,
 長さ3文字の文字列 "CDE" が含まれているかどうかを調べる」
みたいなことをするのだろうと想像しますが,

"ABCDE"の一部である"ABC" は "CDE" と同一か?
"ABCDE"の一部である"BCD" は "CDE" と同一か?
"ABCDE"の一部である"CDE" は "CDE" と同一か?

のように,何の工夫もなく
"ABCDE"の先頭側から順に調べていくのでは都合が悪いのですか?

けろけろ

Re: 文字列から文字列を探索

#9

投稿記事 by けろけろ » 7年前

usao さんが書きました:何に困っているのかがわかりません.


例えば,
「長さ5文字の文字列 "ABCDE" の中に,
 長さ3文字の文字列 "CDE" が含まれているかどうかを調べる」
みたいなことをするのだろうと想像しますが,

"ABCDE"の一部である"ABC" は "CDE" と同一か?
"ABCDE"の一部である"BCD" は "CDE" と同一か?
"ABCDE"の一部である"CDE" は "CDE" と同一か?

のように,何の工夫もなく
"ABCDE"の先頭側から順に調べていくのでは都合が悪いのですか?


どうやるのですか??

box
記事: 2002
登録日時: 13年前

Re: 文字列から文字列を探索

#10

投稿記事 by box » 7年前

けろけろ さんが書きました: どうやるのですか??
くだんの例ならば、探したい文字列"CDE"は3文字なので、
探されたい文字列"ABCDE"について、
1)0~2文字目の3文字を取得する。"ABC"を取得できる。"CDE"とは等しくない。
2)1~3文字目の3文字を取得する。"BCD"を取得できる。"CDE"とは等しくない。
3)2~4文字目の3文字を取得する。"CDE"を取得できる。"CDE"と等しい。探索終了。
てな具合に、探されたい文字列のすべて(今回だと0~4文字目)をすべてカバーできるような
繰り返しを実行すれば、見つかるか見つからないかのいずれかがわかるはずです。
バグのないプログラムはない。
プログラムは思ったとおりには動かない。書いたとおりに動く。

かずま

Re: 文字列から文字列を探索

#11

投稿記事 by かずま » 7年前

けろけろ さんが書きました:
usao さんが書きました: 例えば,
「長さ5文字の文字列 "ABCDE" の中に,
 長さ3文字の文字列 "CDE" が含まれているかどうかを調べる」
みたいなことをするのだろうと想像しますが,

"ABCDE"の一部である"ABC" は "CDE" と同一か?
"ABCDE"の一部である"BCD" は "CDE" と同一か?
"ABCDE"の一部である"CDE" は "CDE" と同一か?

のように,何の工夫もなく
"ABCDE"の先頭側から順に調べていくのでは都合が悪いのですか?
どうやるのですか??

コード:

#include <stdio.h>

int match(char *a, char *b)
{
    int j;
    for (j = 0; j < 3; j++)
        if (a[0+j] != b[j]) break;
    if (j == 3) return 1;
    for (j = 0; j < 3; j++)
        if (a[1+j] != b[j]) break;
    if (j == 3) return 1;
    for (j = 0; j < 3; j++)
        if (a[2+j] != b[j]) break;
    if (j == 3) return 1;
    return 0;
}

int main(void)
{
    char a[] = "ABCDE", b[] = "CDE";
    if (match(a, b))
        puts("found");
    else
        puts("not found");
    return 0;
}
同じことを何度も繰り返すならループにします。

コード:

#include <stdio.h>

int match(char *a, char *b)
{
    int i, j;
    for (i = 0; i <= 5 - 3; i++) {
        for (j = 0; j < 3; j++)
            if (a[i+j] != b[j]) break;
        if (j == 3) return 1;
    }
    return 0;
}
strstr を使ってはいけないのはなぜですか?
strlen, strchr, strncmp も使ってはいけないのですか?

strstr を使ったら書けるのですか?
書けるのなら、ここに提示してください。

閉鎖

“C言語何でも質問掲示板” へ戻る