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

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

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

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

C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

Q&A

解決済

4回答

6435閲覧

atoi関数を自作する

strike1217

総合スコア651

C

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

C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

0グッド

0クリップ

投稿2017/05/29 05:22

int strtoi(char *str){ int num = 0; while(1){ if(*str>='0' && *str<='9'){ if(*str == 0) break; else { num = num * 10 +(*str - '0'); // 文字数字変換 str++; } } else{ num = 0; break; } } return num; }

数字と文字の判定を行うところがおかしいようです。

if(*str>='0' && *str<='9')ここがうまくできていないようです。
・・・?
なぜでしょうか??

if( (*str>='a'&& *str<='z') || (*str>='A' && *str<='Z'))
こちらはうまくできます。

どうしてか理由が分かりません。
どなたか教えてください。

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

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

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

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

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

episteme

2017/05/29 05:57

「うまくできていない」を説明せよ。
guest

回答4

0

ループを抜ける際に、下のelseに入るので、必ずnum = 0にリセットされてしまいます。if(*str>='0' && *str<='9')の条件がある以上、上のif(*str == 0)に入ることはありません。

なお、本来のatoiは先頭から見て数字として読めるところまでを返す、つまり"123abc"なら「123」が返る、とのことです。

投稿2017/05/29 05:27

maisumakun

総合スコア145183

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

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

strike1217

2017/05/29 05:51

while文のループを抜けたときに、elseに入ってしまうということですか??
maisumakun

2017/05/29 06:16 編集

上のif-breakに入ることがない→下のelseでしかループを抜けられない、ということです。
guest

0

ベストアンサー

if(*str == 0)
これの場所が悪いですね。

if(*str>='0' && str<='9'){
これの中に書いてあるので、そもそも使われないコードです。
よって
str == 0の場合は、最後のelseに入ってしまい、常に0が返っています。

こうしてみましょう。

c

1int strtoi(char *str){ 2 int num = 0; 3 4 while(1){ 5 if(*str == 0){ 6 break; 7 } 8 else if(*str>='0' && *str<='9'){ 9 num = num * 10 +(*str - '0'); // 文字数字変換 10 str++; 11 } 12 else{ 13 num = 0; 14 break; 15 } 16 } 17 return num; 18}

投稿2017/05/29 05:59

ttyp03

総合スコア16998

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

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

strike1217

2017/05/29 06:01

if(*str == 0) break; がelseの中に入ってしまうんですか?
ttyp03

2017/05/29 06:03

そうです。 if(*str>='0' && *str<='9') この条件は'0'~'9'なので、そもそもNULL文字は一致しません。 なので、elseの方に行ってしまいます。
strike1217

2017/05/29 06:07

ああ~~~ そうですね! 最後に必ずNULL文字があるので、文字列の最後のNULL文字がやってきたら、必ずelseの中に入って0になってしまうんですね!!
ttyp03

2017/05/29 06:09

そゆことです。
strike1217

2017/05/29 06:29

break;の有効範囲は1スコープ(1つの{})内ですか? それとも、breakを使ったら、たくさんの入れ子スコープであっても即while文を抜けるのでしょうか??
ttyp03

2017/05/29 06:33

一番内側のループにのみ有効です。 while(1){  while(1){   break; // (1)へ  }  // (1)  break; // (2)へ } // (2)
strike1217

2017/05/29 06:36 編集

while(1){ if(){ if(){ break; } } } この場合のbreakはwhile文を即抜けますか??
ttyp03

2017/05/29 06:37

抜けます。 疑問に思ったら簡単なコードを書いて動かしてみるといいですよ。
strike1217

2017/05/29 06:39

わかりました。 breakはスコープ単位ではなく、ループ単位なのですね!
guest

0

c

1if(*str>='0' && *str<='9'){ 2

が問題なのではなく

c

1else{ 2 num = 0; 3 break; 4}

によってそれまでせっかく計算してきた結果が0で上書きしてから終了しているのが問題という事では無いでしょうか

投稿2017/05/29 05:35

HiroshiWatanabe

総合スコア2160

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

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

0

if(*str>='0' && *str<='9'){ ← これが真であるなら if(*str == 0) ← この評価式は常に偽となるので break; ← breakされることがなく、結果的に while-loop を抜け出せない else { ...

投稿2017/05/29 05:29

episteme

総合スコア16614

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問