前提・実現したいこと
ファイルから読み込んだ配列を選択ソートで昇順に並び替えて二分探索で探索をするというプログラミングを作成しています。ただし、二分探索は再帰関数の呼び出しで作成したいと考えています。さらに探索キーと一致する要素が複数存在するときはその添え字の全てを表示するように作成したいです。どのように修正すればよいのかが知りたいです。まだまだプログラミング初学者なため出来るだけ簡単に分かりやすくご教授いただければ幸いです。よろしくお願いします。
発生している問題・エラーメッセージ
コンパイルして実行したのですが探索できません。
該当のソースコード
c言語
1#include <stdio.h> 2 3#define MAXDATE 10000 4 5#define _YES 1 6#define _NO 0 7 8int fileopen(int n, int v[]) 9{ 10 int i; 11 char filename[20]; 12 FILE *fin; 13 14 puts("ファイル名を入力してください。"); 15 printf("filename ="); 16 scanf("%s", filename); 17 18 if ((fin = fopen(filename, "r"))==NULL) { 19 printf("ファイルを開くことが出来ません。\n"); 20 return 1; 21 } 22 23n = 0; 24 while (fscanf(fin, "%d", &v[n])==1) n++; 25 fclose(fin); 26 27 for (i = 0; i < n; i++) 28 { 29 fscanf(fin, "%d", &v[i]); 30 } 31 32 return n; 33} 34 35void selectionsort(int n, int v[]) 36{ 37 int i, j, k; 38 int tmp; 39 40 for (i = 0; i < n - 1; i++) { 41 j = i; 42 for (k = i + 1; k < n; k++) { 43 if (v[j] > v[k]) { 44} 45 } 46 tmp = v[j]; 47 v[j] = v[i]; 48 v[i] = tmp; 49 } 50} 51 52int binarySearch(int v[], int x, int lowid, int highid) 53 { 54 int midid = (lowid + highid) / 2; 55 int found = _NO; 56 57 if(v[midid] == x) { 58 found = _YES; 59 return midid; 60 } 61 else if(lowid > highid) { 62 return -1; 63 } 64 else if(v[midid] > x) { 65return binarySearch(v, x, lowid, midid - 1); 66 } 67 else { 68 return binarySearch(v, x, midid + 1, highid); 69 } 70} 71 72int main(void) 73{ 74 int i, j, n, x, num; 75 int midid; 76 int found; 77 int v[MAXDATE]; 78 79 num = fileopen(n, v); 80 81 selectionsort(num, v); 82 83 for (i = 0; i < num; i++) { 84 printf("v[%d] = %d\n", i, v[i]); 85 } 86 87 while (scanf("%d", &x)==1) { 88 int lowid = 0; 89int highid = num - 1; 90 91 binarySearch(v, x, lowid, highid); 92 93 printf("%d", midid); 94 95 if (found == _YES) { 96 i = j = midid; 97 while (--i >= 0 && v[i] == x) ; 98 while (++j < n && v[j] == x) ; 99 while (++i < j) printf("%dはv[%d]と一致しました。\n", x, i); 100 } 101else { 102 printf("%dはデータから見つかりませんでした。\n", x); 103 } 104 } 105 106 printf("さようなら。\n"); 107 108 return 0; 109} 110 111
c言語
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。