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

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

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

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

Q&A

解決済

7回答

1285閲覧

この回答ではどうしてできないのか分かりません。(C, 配列)

gotutiyan

総合スコア14

C

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

0グッド

0クリップ

投稿2017/02/15 04:36

###前提・実現したいこと
あるC言語の入門書における、配列の分野での問題です。
0~10点の整数で点数をつけるテストで、20人分の点数を入力する。
入力された数値を元に、以下のような形で集計して表示させる。

1点 ○人
2点 ×人


10点 □人

###発生している問題・エラーメッセージ
エラーメッセージは出ませんが、上記における○や×といった数値が848993459のようにおかしくなります。他は大丈夫です。
解答があり、そこには自分よりもスマートな回答が載っていましたが、自分の回答ではどうしてできないのか分かりません。

###該当のソースコード

C

1#include <stdio.h> 2 3int main() { 4 int data[20]; 5 int score[11]; 6 int loop,loop2 ; 7 8 //1-20番目までの人のそれぞれの点数を入力 9 10 for (loop = 0; loop < 20; loop++) { 11 do { 12 13 printf("%d番目の人の点数を入力してください: ", loop + 1); 14 scanf("%d", &data[loop]); 15 } while (data[loop]<0 || 10<data[loop]); 16 } 17 //0-10の点数について、1-20番までの人を毎回照合。点数が一致する度にscore[点数]を1増やす。 18 19 for (loop2 = 0; loop2 < 11; loop2++) { 20 for (loop = 0; loop < 20; loop++) { 21 if (data[loop] == loop2) { 22 score[loop2]++; 23 } 24 } 25 } 26 27 //それぞれの点数について増やしたscore[点数]を表示 28 for (loop2 = 0; loop2 < 11; loop2++) { 29 printf("%d点は%d人です。\n", loop2 , score[loop2]); 30 } 31 32 return 0; 33}

###試したこと

###補足情報(言語/FW/ツール等のバージョンなど)
Visual Studio 2017 RC Community
C言語
Windows7

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

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

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

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

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

guest

回答7

0

ベストアンサー

C

1int score[11];

ここで変数宣言するだけでは、score配列の「中身」は「不定」の状態であり、メモリ上の数値はめちゃくちゃなものが入っています。なので、そこに++で1を足しても、0からのカウントアップではなくめちゃくちゃな数字に1足されるだけです。

C

1int score[11] = {};

Cではこう書くだけで配列の0初期化ができるので、これで0からのカウントアップになるはずです。

訂正

すみません、上のコードはC++ではいけるのですが、純粋なCではコンパイルエラーになります。こう書いてください。

C

1int score[11] = {0};

なんでこうなるのかという説明は、以下のページに詳しいことが書いてあります。
https://cpplover.blogspot.jp/2010/09/blog-post_18.html

投稿2017/02/15 04:43

編集2017/02/15 04:57
masaya_ohashi

総合スコア9206

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

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

gotutiyan

2017/02/15 04:58

初期化をすることで解決しました。それとともに、0の初期化の方法がそのような方法でできるとは初めて知りました。貴重なアドバイスありがとうございました。
masaya_ohashi

2017/02/15 05:00

すみません、ベストアンサーに選んでもらった後なんですが訂正を足しておきました。実際コーディング刷る際は気をつけてください。
gotutiyan

2017/02/15 05:14

確認しました。ありがとうございます。
guest

0

score[]が初期化されていないままscore[loop2]++;としているので結果が不定になるんだと思います。
最初にscoreの配列の内容を0で初期化するコードを追加すればいいと思います。

投稿2017/02/15 04:41

HiroshiWatanabe

総合スコア2160

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

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

gotutiyan

2017/02/15 04:59

初期化をすることで解決しました。ありがとうございました。
guest

0

配列score[]の要素が初期化されていないためこれを++でインクリメントしても得たい値は得られません。
初期化されていないとは「0かも知れないし848993450かもしれない-5000かも知れないそれ以外かもしれない」値が設定されています。

以下のようにloop2のfor文の処理の最初に0を代入してください。

C

1 for (loop2 = 0; loop2 < 11; loop2++) { 2 score[loop2] = 0; // このように0で初期化してください。 3 for (loop = 0; loop < 20; loop++) { 4 if (data[loop] == loop2) { 5 score[loop2]++; 6 } 7 } 8 }

投稿2017/02/15 04:45

Y.H.

総合スコア7914

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

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

gotutiyan

2017/02/15 04:59

初期化をすることで解決しました。ありがとうございました。
guest

0

score[n]を初期化しないと処理系によってはうまくいきません。
初期値が0というのは処理系によってはあるかもしれませんが、そうでない前提で書いたほうがいいです。

投稿2017/02/15 04:45

katsuya141

総合スコア367

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

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

gotutiyan

2017/02/15 04:59

初期化をすることで解決しました。ありがとうございました。
guest

0

変数scoreを初期化していないだけではないでしょうか。
変数は明示的に初期化しないと不定値が入っています。
なので最初に0で初期化する処理を加えれば良いと思いますよ。

投稿2017/02/15 04:42

ttyp03

総合スコア16998

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

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

gotutiyan

2017/02/15 04:59

初期化をすることで解決しました。ありがとうございました。
guest

0

int score[11];と宣言しただけでは、値は不定です。そのまま使うと、まともに動きません。

最初にscore[]の各要素を0クリアしておきましょう。

投稿2017/02/15 04:42

maisumakun

総合スコア145183

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

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

gotutiyan

2017/02/15 04:59

初期化をすることで解決しました。ありがとうございました。
guest

0

score配列の状態が不定なためです。最初に全要素を0で初期化しましょう。

投稿2017/02/15 04:41

can110

総合スコア38264

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

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

gotutiyan

2017/02/15 04:59

初期化をすることで解決しました。ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問