
C言語の線形探索の課題なんですが
5つの整数を入力して
その入力した値からみつけたい値を探索する課題なのですが
#include <stdio.h>
/*--- 要素数nの配列aからkeyと一致する要素を線形探索 ---*/
int search(const int a[], int n, int key)
{
int i = 0;
while (1) {
if (i == n)
return (-1);/* 探索失敗 */
if (a[i] == key)
return (i);/* 探索成功 */
i++;
}
}
int main(void)
{
int i, ky, idx;
int x[4];
int nx = sizeof(x) / sizeof(x[0]);
printf("%d個の整数を入力してください。\n", nx);
for (i = 0; i < nx; i++) {
printf("x[%d]:", i);
scanf("%d", &x[i]);
}
printf("探す値:");
scanf("%d", &ky);
idx = search(x, nx, ky);/* 配列xから値がkyである要素を線形探索 */
if (idx == -1)
puts("探索に失敗しました。");
else
printf("%dは%d番目にあります。\n", ky, idx + 1);
return (0);
}
ここまではわかるのですが、
x[0]=99
x[1]=99
x[2]=88
x[3]=99
x[4]=22
と入力したときに
99は
1番目に見つかりました
2番目に見つかりました
4番目に見つかりました
と出力したいのですがうまくいきません
線形探索で同じ数値を探索するにはどうすればよいのですか?
No.1ベストアンサー
- 回答日時:
#include <stdio.h>
/*--- 要素数nの配列aからkeyと一致する要素を線形探索 ---*/
int search(const int a[], int n, int key)
{
int i = 0;
while (1) {
if (i == n) return (-1); /* 探索失敗 */
if (a[i] == key) return (i); /* 探索成功 */
i++;
}
}
int main(void)
{
int i, ky, idx, t, f;
int x[5];
int nx = sizeof(x) / sizeof(x[0]);
printf("%d個の整数を入力してください。\n", nx);
for (i = 0; i < nx; i++) {
printf("x[%d]:", i);
scanf("%d", &x[i]);
}
printf("探す値:");
scanf("%d", &ky);
t = 0;
f = -1;
while (t < nx) {
idx = search(&x[t], nx - t, ky); /* 配列xから値がkyである要素を線形探索 */
if (idx != -1) {
idx += t;
printf("%dは%d番目にあります。\n", ky, idx + 1);
t = idx + 1;
f = 0;
} else
break;
}
if (f) puts("探索に失敗しました。");
return (0);
}
No.3
- 回答日時:
#include <stdio.h>
int search(const int a[], int n, int key)
{
int i = 0;
while(1){
if (i == n) return (-1);
if (a[i] == key) return (i);
i++;
}
}
int main(void)
{
int i, ky, idx;
int x[4];
int nx = sizeof(x) / sizeof(x[0]);
printf("%d個の整数を入力してください。\n", nx);
for (i = 0; i < nx; i++){
printf("x[%d]:", i);
scanf("%d", &x[i]);
}
printf("探す値:");
scanf("%d", &ky);
for(i = 0; i < 4 && (idx = search(&x[i], nx, ky)) != -1; ){
i += idx + 1;
printf("%dは%d番目にあります。\n", ky, i);
nx -= idx + 1;
}
if (i == 0) puts("探索に失敗しました。");
return (0);
}
No.2
- 回答日時:
#include <stdio.h>
typedef void (*callback)(int, void*);
/*--- 要素数nの配列aからkeyと一致する要素を線形探索 ---*/
void search(const int a[], int n, int key, callback cb, void* arg)
{
int i;
for ( i = 0; i < n; ++i ) {
if (a[i] == key) (*cb)(i, arg);
}
}
void found(int n, void* arg) {
printf("%dは%d番目にあります。\n", *(int*)arg, n + 1);
}
int main() {
int x[] = { 99,99,88,99,22 };
int target = 99;
search(x, 5, target, &found, &target);
return 0;
}
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
C言語での引数の省略方法
-
C言語 エラーの原因がわからな...
-
プログラミング☆
-
C言語の課題です
-
整数データの配列から同じ値の...
-
複数桁10進数の*桁目だけを抽出...
-
if と配列の組み合わせ
-
数値を入力して1からその数値ま...
-
エラー 添字が付けられた値が、...
-
「指定されたキャストは有効で...
-
C# 配列時のrefの意味
-
C言語 逆順の配列の仕方を教え...
-
ラップ関数とはどんなものですか?
-
c言語の配列を使ってサイコロを...
-
c言語のプログラムが動きません
-
#define _CRT_SECURE_NO_WARNIN...
-
C言語で、数値の桁数を求めるに...
-
ポインタを使って関数の値の...
-
CStringの配列要素を関数で受け...
-
深さ優先探索について・・・
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
複数桁10進数の*桁目だけを抽出...
-
C言語での引数の省略方法
-
「指定されたキャストは有効で...
-
#define _CRT_SECURE_NO_WARNIN...
-
C言語 エラーの原因がわからな...
-
【C++】関数ポインタの使い方
-
ラップ関数とはどんなものですか?
-
エラー 添字が付けられた値が、...
-
acceptをalarmでタイムアウトさ...
-
if と配列の組み合わせ
-
式は定数値が必要です」という...
-
「{ } で囲むだけ」は正しい?
-
(マルチスレッド)_beginthrea...
-
構造体の勉強中です 合計点の高...
-
数字列を3桁ごとにカンマで区切...
-
return 1L
-
std::set<int> で、ある値が何...
-
C#のコンパイルエラーCS0120に...
-
比較回数と交換回数表示について
-
C言語で分からないところがあり...
おすすめ情報