//【 構造体のポインタ配列を qsort するプログラム例 】 // 実行時間の短い順にならべるプログラムを関数を作って // すっきりしたいにですが、うまくいかないので教えてください // NDATAを定義しているのですがbest_tenをmallocで確保して、 // countの代わりに使いたいのですが。 #include <float.h> #include <time.h> #include <stdio.h> #include <stdlib.h> #define NDATA ((sizeof best_ten)/(sizeof(BEST_TEN))) typedef struct { int tm_year; int tm_mon; int tm_mday; int tm_hour; int tm_min; int tm_sec; double best; } BEST_TEN; // --------------- 比較用の関数 cmp ------------------- int cmpptr( const void *p, const void *q ) { return (*(BEST_TEN**)p)->best - (*(BEST_TEN**)q)->best; } // ---------------------------------------------------- char dtfile[] = "LACKNUM.DAT"; int main(void) { FILE *lstfp; double best; int i,j=0; BEST_TEN best_ten[100]={0}; int count=0; if((lstfp =fopen(dtfile, "rb")) == NULL){ printf("ファイルを作成します。 \n\n"); best = DBL_MAX; }else{ struct tm lst; printf("\n過去の履歴のコピー\n-------------------------- \n"); while((i = fread(&lst,sizeof(struct tm), 1, lstfp)) > 0 ){ printf("%d年 %d月 %d日 %d時 %d分 %d秒\n", lst.tm_year + 1900, lst.tm_mon + 1, lst.tm_mday, lst.tm_hour, lst.tm_min, lst.tm_sec); fread(&best, sizeof(double), 1, lstfp); printf("得点(所要時間)は %.1f秒です。\n\n", best); // 画面が一瞬で消えてしまうのを防止 // 一瞬で画面が消えてしまう場合には、以下の文を入力します。 best_ten[j].tm_year=lst.tm_year; best_ten[j].tm_mon=lst.tm_mon; best_ten[j].tm_mday=lst.tm_mday; best_ten[j].tm_hour=lst.tm_hour; best_ten[j].tm_min=lst.tm_min; best_ten[j].tm_sec=lst.tm_sec; best_ten[j].best=best; /*printf( "%d年 %d月 %d日 %d時 %d分 %d秒 %.lf秒\n\n" , best_ten[j].tm_year + 1900, best_ten[j].tm_mon + 1, best_ten[j].tm_mday, best_ten[j].tm_hour, best_ten[j].tm_min, best_ten[j].tm_sec,best_ten[j].best);*/ j++; count++; } printf("countは %dです。\n\n", count); } printf("count2は %dです。\n\n", count); printf("NDATAは %dです。\n\n", NDATA); BEST_TEN *plst[NDATA]; for( i = 0; i < count; i++ ) { plst[i] = &best_ten[i]; } qsort( plst, count, sizeof(BEST_TEN*), cmpptr ); printf("\n過去のbestten\n-------------------------- \n"); // 並べ替え後の内容を表示 for(i=0;i<count;i++){ printf( "%d年 %d月 %d日 %d時 %d分 %d秒 %.lf秒\n" ,plst[i]->tm_year+1900, plst[i]->tm_mon+1, plst[i]->tm_mday, plst[i]->tm_hour,plst[i]->tm_min,plst[i]->tm_sec ); printf("得点(所要時間)は %.1f秒です。\n\n", plst[i]->best); } fflush(stdin); getchar(); fclose(lstfp); return 0; } /*実行結果 ....@naka ~/qsort/struct_sort $ gcc -o qsort4 qsort4.c -lpdcursesw ....@naka ~/qsort/struct_sort $ qsort4 過去の履歴のコピー -------------------------- 2015年 10月 27日 19時 9分 59秒 得点(所要時間)は 11.0秒です。 2016年 1月 4日 19時 15分 11秒 得点(所要時間)は 8.0秒です。 2016年 1月 4日 19時 16分 8秒 得点(所要時間)は 9.0秒です。 2016年 1月 4日 19時 16分 39秒 得点(所要時間)は 10.0秒です。 2016年 1月 4日 19時 19分 7秒 得点(所要時間)は 10.0秒です。 2016年 1月 4日 19時 21分 11秒 得点(所要時間)は 10.0秒です。 2016年 1月 4日 19時 21分 44秒 得点(所要時間)は 8.0秒です。 2016年 1月 4日 19時 22分 55秒 得点(所要時間)は 13.0秒です。 2016年 1月 5日 21時 31分 52秒 得点(所要時間)は 12.0秒です。 2016年 1月 5日 21時 33分 29秒 得点(所要時間)は 10.0秒です。 過去のbestten -------------------------- 2016年 1月 4日 19時 15分 11秒 0秒 得点(所要時間)は 8.0秒です。 2016年 1月 4日 19時 21分 44秒 0秒 得点(所要時間)は 8.0秒です。 2016年 1月 4日 19時 16分 8秒 0秒 得点(所要時間)は 9.0秒です。 2016年 1月 4日 19時 19分 7秒 0秒 得点(所要時間)は 10.0秒です。 2016年 1月 5日 21時 33分 29秒 0秒 得点(所要時間)は 10.0秒です。 2016年 1月 4日 19時 16分 39秒 0秒 得点(所要時間)は 10.0秒です。 2016年 1月 4日 19時 21分 11秒 0秒 得点(所要時間)は 10.0秒です。 2015年 10月 27日 19時 9分 59秒 0秒 得点(所要時間)は 11.0秒です。 2016年 1月 5日 21時 31分 52秒 0秒 得点(所要時間)は 12.0秒です。 2016年 1月 4日 19時 22分 55秒 0秒 得点(所要時間)は 13.0秒です。 */ ```
履歴のファイルからデータを読み出す前に、そのデータを保存する領域をmallocする実装は可能でしょうが、そうしてmallocした領域へのポインタの配列を保持する事が必要なので、best_10のようなデータ配列を使う場合と大差ないコードになると思いますから、「すっきり」とはいかないと思います。過去履歴の件数が100件を超えても正常に動作するというメリットはあります。
すみません。漠然としたお願いで申し訳ありませんでした。
私は一連の質問を依頼してこちらが何をしているか分かってもらっている人でしたら、分かっていただいたと思います。要は配列でも、可変のポインタ配列でもおなじということですね。勉強のためにmalloc使って、NDATAをうまく使えるようにしたかったのです。
すこしmallocを復習してからやってみます。