BohYoh.comトップページへ

C言語によるアルゴリズムとデータ構造

戻る  

演習2-6の解答

 0.1~:*
 0.2~:***
 0.3~:*
 (以下省略)
 視力の分布を右図のようなグラフで出力せよ。
 すなわち、人数分だけ記号文字*を繰り返し表示すること。

/* 演習2-6 身体検査データ用構造体の配列(*によるグラフで表示) */ #include <stdio.h> #define VMAX 21 /* 視力の最大値2.1 × 10 */ /*--- 身体検査データ型 ---*/ typedef struct { char name[20]; /* 氏名 */ int height; /* 身長 */ double vision; /* 視力 */ } PhysCheck; /*--- 身長の平均値を求める ---*/ double ave_height(const PhysCheck dat[], int n) { int i; double sum = 0; for (i = 0; i < n; i++) sum += dat[i].height; return (sum / n); } /*--- 視力の分布を求める ---*/ void dist_vision(const PhysCheck dat[], int n, int dist[]) { int i; for (i = 0; i < VMAX; i++) dist[i] = 0; for (i = 0; i < n; i++) if (dat[i].vision >= 0.0 && dat[i].vision <= VMAX / 10.0) dist[(int)(dat[i].vision * 10)]++; } int main(void) { int i, j; PhysCheck x[] = { {"AKANE Kouichi", 170, 2.0}, {"TOKUTOMI Shyuji", 173, 1.5}, {"NISHIDA Taro", 170, 0.5}, {"TSUJINO Jiro", 175, 0.4}, {"MATSUO Keiji", 167, 0.6}, {"OHYAMA Kazuhiro", 168, 0.2}, {"KITAYAMA Takuya", 179, 0.6}, {"TANAKA Rina", 158, 0.9}, }; int nx = sizeof(x) / sizeof(x[0]); /* 人数 */ int vdist[VMAX]; /* 視力の分布 */ puts("■□■ 身体検査一覧表 ■□■"); puts(" 氏名 身長 視力 "); puts("----------------------------"); for (i = 0; i < nx; i++) printf("%-18.18s%4d%5.1f\n", x[i].name, x[i].height, x[i].vision); printf("\n平均身長:%5.1fcm\n", ave_height(x, nx)); dist_vision(x, nx, vdist); /* 視力の分布を求める */ printf("\n視力の分布\n"); for (i = 0; i < VMAX; i++) { printf("%3.1f~:", i / 10.0); for (j = 0; j < vdist[i]; j++) putchar('*'); putchar('\n'); } return (0); }


戻る