前提・実現したいこと
データを、昇順(その値が小さいものから大きいものの順)に並べ替えること。 ソートのアルゴリズムには挟み込み法(演習開始時に解説する)を用いること。 ソート処理全体を 1個の関数にまとめること(その関数内で別の関数を呼び出してもよい)。
発生している問題・エラーメッセージ
inputにいれて実行すると結果が以下のようになってしまう
4124
5635
23423
15
53
123412
634
2345
0
0
0
0
0
またsort内で書くものがわからない
該当のソースコード
コード C #include <stdio.h> #include <stdlib.h> #define MAX 10 #define FALSE 0 int input(FILE *in, int s[]); int output(int s[], FILE *out); void sort(int data[]); int main(int argc, char *argv[]) { int i; int capa = 0; FILE *nm1, *nm2; if ((nm1 = fopen(argv[1], "r")) == NULL) { fprintf(stderr, "Can't open input file."); return -1; } if ((nm2 = fopen(argv[2], "w")) == NULL) { fprintf(stderr, "Can't open output file."); return -1; } fscanf(nm1, "%d", &capa); int* number = (int*) malloc(sizeof(int*) * (capa)); for (i = 0; i < capa; i++) { input(nm1, &number[i]); } sort(number); for (i = 0; i < capa; i++) { output(&number[i], nm2); } return 0; } int input(FILE *in, int *s) { if ((fscanf(in, "%d", s)) == '\0') { return -1; } else { return 0; } } void sort(int data[]) { int i = 1; while (FALSE) { int count = 0; if (data[i - 1] > data[i]) { int j, tmp; tmp = data[i]; for (j = 0; j < i; j++) { } } if (count == 0) break; } i++; } int output(int s[], FILE *out) { if ((fprintf(out, "%d\n", *s)) == '\0') { return -1; } else { return 0; } }
### 試したこと ### 補足情報(FW/ツールのバージョンなど) eclipse用いてます linuxです
このままではコードが読みづらいので、質問を編集し、<code>ボタンを押し、出てくる’’’の枠の中にコードを貼り付けてください