質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.49%
C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

Q&A

2回答

6739閲覧

点数別分布グラフ

reotantan

総合スコア295

C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

0グッド

1クリップ

投稿2015/08/26 11:39

点数分布のグラフですが、少し長いように感じました。もう少し短くすることはできますか?
またこのコードに対して何かご意見がありましたらお願いします。

#include<stdio.h> #define NUMBER 80 int main(void) { int i,j; int num; /*実際の人数*/ int tensu[NUMBER]; /*学生の点数*/ int bunpu[11]={0};/*分布*/ printf("type numbers" ); do{ scanf("%d",&num ); if(num<1 ||num>NUMBER) printf("\aneed[over 1and under%d]:",NUMBER ); }while(num<1||num>NUMBER); puts("type score"); for(i=0;i<num;i++){ printf("%2d:",i+1 ); do{ scanf("%d",&tensu[i]); if(tensu[i]<0 ||tensu[i]>100) printf("\a[over 0 and under 100]" ); }while(tensu[i]<0 || tensu[i]>100); bunpu[tensu[i]/10]++; } puts("\n graph"); printf(" 100:" ); for(j=0;j<bunpu[10];j++) putchar('*'); putchar('\n'); for(i=9; i>=0;i--){ printf("%3d-%3d:",i*10,i*10+9); for(j=0;j<bunpu[i];j++) putchar('*'); putchar('\n'); } return 0; } コード

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

長さで言えば短くなっていませんが、
0. 数値入力処理が2回かかれているので最大値と最小値の間の値を受け付ける関数に共通化できます。
0. エラー表示とループ終了で同じ判定をしているのでエラーでなければループ終了にすれば判定は1回になります。
0. 100点の場合とそれ以外の場合で表示ラベルが違うだけなので、if分岐で*の表示は共通にできます。
0. 度数分布の他に点数を利用するのでなければわざわざ配列で全部記録する必要はありません。
0. forのあとの{}を省略するのであればforの後ろにあった方がforの影響範囲がわかりやすいと思います。

上記を踏まえると以下のコードになります

C

1#include<stdio.h> 2 3#define NUMBER 80 4 5int getInput(int min, int max){ 6 int input; 7 8 while(1){ 9 scanf("%d", &input); 10 if(input < min || max < input){ 11 printf("\aneed[over %d and under%d]:", min, max ); 12 continue; 13 } 14 return input; 15 } 16} 17 18int main(void) 19{ 20 int i, j; 21 int num; /*実際の人数*/ 22 int bunpu[11]={0};/*分布*/ 23 24 printf("type numbers" ); 25 num = getInput(1, NUMBER); 26 27 puts("type score"); 28 for(i=0;i<num;i++){ 29 printf("%2d:",i+1 ); 30 // 学生の点数を取得して度数分布に登録 31 bunpu[getInput(0, 100)/10]++; 32 } 33 puts("\n graph"); 34 35 for(i=10; i>=0;i--){ 36 if(i==10){ 37 printf(" 100:" ); 38 }else{ 39 printf("%3d-%3d:",i*10,i*10+9); 40 } 41 for(j=0;j<bunpu[i];j++) putchar('*'); 42 putchar('\n'); 43 } 44 45 return 0; 46}

投稿2015/08/26 17:10

kutsulog

総合スコア985

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

短くしたいだけなら複数回登場する処理を関数化しても行数増えちゃいますし、
ここくらいでしょうか? 2行減りました。

c

1 printf(" 100:" ); 2 for(i=10; i>=0;i--){ 3 if(i!=10) 4 printf("%3d-%3d:",i*10,i*10+9); 5 for(j=0;j<bunpu[i];j++) 6 putchar('*'); 7 putchar('\n'); 8 }

全体で長くなってもmainがすっきりすればいいなら2つほど関数化してしまうか…
今のままなら余り必要ないですが、将来科目別とかに機能拡大していくことを見越して等

c

1#include<stdio.h> 2 3#define NUMBER 80 4 5int main(void) 6{ 7 int i; 8 int num; /*実際の人数*/ 9 int tensu[NUMBER]; /*学生の点数*/ 10 int bunpu[11]={0};/*分布*/ 11 12 printf("type numbers" ); 13 num = fn_scanf(1,NUMBER); 14 15 puts("type score"); 16 for(i=0;i<num;i++){ 17 printf("%2d:",i+1 ); 18 tensu[i] = fn_scanf(0,100); 19 bunpu[tensu[i]/10]++; 20 } 21 puts("\n graph"); 22 printf(" 100:" ); 23 for(i=10; i>=0;i--){ 24 if(i!=10) 25 printf("%3d-%3d:",i*10,i*10+9); 26 fn_prot(bunpu[i]); 27 } 28 29 return 0; 30} 31 32int fn_scanf(b,t){ 33 int num; 34 do{ 35 scanf("%d",&num); 36 if(num<b || num>t) 37 printf("\aneed[over %d and under %d]:",t,b); 38 }while(num<b || num>t); 39 return num; 40} 41 42void fn_prot(num){ 43 int i; 44 for(i=0;i<num;i++) 45 putchar('*'); 46 putchar('\n'); 47}

投稿2015/08/26 17:04

hirohiro

総合スコア2068

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.49%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問