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

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

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

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

UNIX

UNIXとは、AT&Tのベル研究所で開発されたコンピューター用のマルチユーザー・マルチタスクのオペレーションシステム(OS)です。政府や教育機関や研究所で広範囲に採用されています。

Q&A

解決済

4回答

411閲覧

C言語でwhileとif文を組み合わせたコードのエラー

退会済みユーザー

退会済みユーザー

総合スコア0

C

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

UNIX

UNIXとは、AT&Tのベル研究所で開発されたコンピューター用のマルチユーザー・マルチタスクのオペレーションシステム(OS)です。政府や教育機関や研究所で広範囲に採用されています。

0グッド

0クリップ

投稿2017/11/13 02:58

編集2017/11/13 03:20

###前提・実現したいこと
ここに質問したいことを詳細に書いてください
文字が小文字アルファベットの場合は、入力文字を入力してその大文字を返し、
それ以外の場合は、新しい入力を促すコードを書いています。
100回の反復後にプログラムが終了するように設計しています。

実行したい結果

input a small character = 7 input a small character = 0 input a small character = k capital is = K

###発生している問題・エラーメッセージ

いただいたアドバイスを元にコードを修正しましたが、実行すると100回ではなく一度しか実行されないという問題が発生しています。

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

c

1#include<stdio.h> 2#include <ctype.h> 3int main(){ 4 char a; 5 int i = 0; 6 while(i<100){ 7 printf("input a small character ="); 8 scanf("%c", &a); 9 if(a>='a' && a<='z'){ 10 char b = toupper(a); 11 printf("capital is =%c\n", b); 12 } 13 i = i +1; 14 return 0; 15 } 16}

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

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

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

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

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

guest

回答4

0

ベストアンサー

日本語がおかしいだけかと思ったら、そのおかしい日本語の通りにプログラムを書いていますね。結果的におかしいプログラムになっています。

文字が小文字アルファベットの場合は、入力文字を入力してその大文字を返し、

それ以外の場合は、新しい入力を促すコードを書いています。

最初に何を判断しているつもりでしょうか?まず入力しないと、判断する文字がありません。

以下を100回繰り返す。文字を入力して、その文字が小文字アルファベットの場合は、その大文字を返し、

それ以外の場合は何もしない。

というのが正しい処理です。

あと、直接質問とは関係無いですが、scanfは、初心者が使うには難しい関数です。まあscanf("%c",&a);くらいであれば、ほぼa=getchar();と同じ機能なので、難しくないのですが、一般には書式指定文字列を熟知していないと使いこなせない上級者向けの関数です。
また、もしscanfを使うなら、返値を必ずチェックしましょう。

投稿2017/11/13 03:08

編集2017/11/13 03:12
otn

総合スコア84529

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

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

退会済みユーザー

退会済みユーザー

2017/11/13 03:38 編集

ご丁寧にアドバイスいただきましてありがとうございます。 scanfは難しい関数であるということを存じ上げませんでした。 課題で必須なので、初心者ですが書式指定文字列とともに勉強します。
otn

2017/11/13 03:28

回答に書いた通り、`scanf("%c",&a);`くらいであれば大丈夫です。 書式が複雑な場合、初心者には、fgets + sscanf をお薦めします。 いずれにせよ、返値を必ず確認して下さい。 文章通りにプログラムを書くスキルはお持ちのようなので、ロジックが整理できれば大丈夫だと思います。
退会済みユーザー

退会済みユーザー

2017/11/13 03:38

貴重なアドバイスをいただきましてありがとうございました。
otn

2017/11/13 03:46

> 一度しか実行されない returnしているからですね。
guest

0

100回は入力が大変なので10回のサンプルプログラム

c

1#include<stdio.h> 2#include <ctype.h> 3int main(){ 4 char a; 5 int i = 0; 6 while(i<10){ 7 printf("input a small character ="); 8 scanf("\n%c", &a); 9 if(a>='a' && a<='z'){ 10 char b = toupper(a); 11 printf("capital is =%c\n", b); 12 } 13 i = i +1; 14 } 15 return 0; 16}

投稿2017/11/13 03:52

A.Ichi

総合スコア4070

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

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

0

コンパイルエラーはたいてい、エラーメッセージをそのままググると対処方法がでてきます。
今回は、メッセージそのままの意味で、aが初期化されていないのにif文の判定で使っているのでエラーがでています。

int i = 0;のように、aを初期化(else節に分岐する値で)してみてください。

投稿2017/11/13 03:30

momon-ga

総合スコア4820

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

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

退会済みユーザー

退会済みユーザー

2017/11/13 03:37

ご回答いただきましてありがとうございました。
guest

0

現象は書いてありますが、そこから何を質問されたいのかよく分かりませんが、さしあたり、変数 a に値が代入されていないので、まず a にしかるべき値を代入する必要があります。
途中で、scanf により a に値が入りますが、その前に a の値を参照していますので…

投稿2017/11/13 03:02

編集2017/11/13 03:04
ockeghem

総合スコア11701

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

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

退会済みユーザー

退会済みユーザー

2017/11/13 03:24

ご指摘いただきましてありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問