• 締切済み

C言語で 数字を配列に入力し,q Qで終了させたい

O.reillyのC実践プログラミング第3版で、勉強しています。 p105の 実習7-6 「いくつかの数字が入力されたとき、正の数がいくつあるか、負の数がいくつあるかを  数えるプログラムを作成せよ」に取り組んでみました。    例えば 「1 -1 2 -2 3 -3 -4 -5 で8つの数があり、正が3 負が5を出力させたい」のです。  入力の終わりは、q,Qで、終了させたいと考えました。  でも、「8個の数字を配列に入力させq、Qで入力終了」のところがうまくいきません。  次のようなプログラムで行き詰まっています。  どこを手直しすればいいのか教えて下さい。 #include <stdio.h> #include <math.h> #define KOSU 10 /*入力できる個数*/ char line[10];/*入力した数を受けるためのバッファ*/ int plus_count = 0;/*プラスカウンター*/ int minus_count = 0;/*マイナスカウンター*/ int number[20]; int given_number; int i; int main(void) { printf("+、ーの数を 入れなさい。(最大20まで)\n 終わるときは、qを入れる\n"); { for(i = 0; i < KOSU; i++) { fgets(line, sizeof(line), stdin); sscanf(line, "%d", &given_number); number[i] = given_number; /*ここからした、qを入れるとそこで終了のはずがうまく動きません 10個入れたらちゃんと終わるのですが。*/ if ( (given_number == 'q') || (given_number == 'Q') ) break; } } for(i = 0;i < KOSU;i++) { printf("number[%d] = %d \n", i, number[i]); } /*正負の数を数えることにする。*/ for(i = 0;i < KOSU;i++) { if(number[i] > 0) plus_count++; else minus_count++; } printf("plus is %d\n",plus_count); printf("minus or zero is %d\n",minus_count); }

みんなの回答

  • Tacosan
  • ベストアンサー率23% (3656/15482)
回答No.3

本題じゃないんだけど: このプログラムでは「1行につき 1個しか入力されない」んだけど, それでいい? つまり, 改行せずに空白で区切って「1 -1 2 -2 3 -3 -4 -5」と入力しても, 「1」しか入力できないよ. あと, このままだと sscanf(line, "%c", &given_number); はどのみちダメ (変換指示と変数の型が違うので未定義動作) ですね>#2. で, 型さえ適切にしておけば負数を入力されてもさほど問題なし... いや, 「空白のあとに q/Q」で問題か? うん, もっと仕様を詰めないとダメだ.

oshiete_q
質問者

お礼

回答いただきありがとうございました。 どうも、fgets と sscanf では、難しいようです。 また、勉強してみます。 まずは、お礼まで。

  • Wr5
  • ベストアンサー率53% (2173/4061)
回答No.2

>sscanf(line, "%d", &given_number); lineに「数字」がないとsscanf()はエラーになります。 そうすると…given_numberに入る値は不定(たぶん変化しない)になります。 ので… >if ( (given_number == 'q') || (given_number == 'Q') ) 'q'または'Q'が入ることもありません。 sscanf()の戻り値を確認して、エラーだった場合にlineに何が入っているかを判定する。 という処理にした方がよいでしょう。 stricmp()で判定するか、line[0]の文字コードを見るか…は仕様次第でしょうかね。 # 後者の方法だと"quick"とかでも抜けることになりますが。 sscanf(line, "%c", &given_number); だと、"-10"とかの入力の時に手間が掛かりますのでがんばる必要が。

oshiete_q
質問者

お礼

解答いただきありがとうございました。 どうも、fgets と sscanf では、難しいようです。 また、勉強してみます。 まずは、お礼まで。

  • TinyPine
  • ベストアンサー率30% (719/2386)
回答No.1

sscanf(line, "%d", &given_number); %dって言うのは10進数を入れなさいだよね。 %c(文字を入れなさい)で受けて、qかQで無い時はそこから0x30を引いて数値に変換してあげれば出来るんじゃないかなぁ。

oshiete_q
質問者

お礼

解答いただきありがとうございました。 どうも、fgets と sscanf では、難しいようです。 また、勉強してみます。 まずは、お礼まで。