• ベストアンサー

指数形式で入力するには

 このプログラムは球の体積を求めるものです。 #include <stdio.h> main() { double r,v,PI=3.1415926535; printf("球の半径(cm)を入力して下さい: "); scanf("%lf",&r); v=4.0*PI*r*r*r/3.0; printf("球の半径=%12.5e (cm) 球の体積=%12.5e (cm^3)\n",r,v); }  現在入力が小数形式(%lf)になっていますが、 1.00007e+002 -1.71005e-001 のような指数形式にしたいと思います。しかし%lfのところを%eや%gに変更して実行すると、 球の半径(cm)を入力して下さい: 1.00000e+001 球の半径=2.66182e-314 (cm) 球の体積= 0.00000e+00 (cm^3) というふうに正常な出力結果が得られません。どのようにすればこのプログラムが正常に動くのでしょうか。  ご存知の方、お手数ですが教えてください。よろしくお願いします。

質問者が選んだベストアンサー

  • ベストアンサー
  • notnot
  • ベストアンサー率47% (4900/10361)
回答No.1

%lf を %e や %g に変えては駄目なのは当たり前。l の意味がお分かりではないのでしょうか? %le や %lg に変えてもいいですが、%lf のままでも指数入力できませんか?

eliteyoshi
質問者

お礼

 ご回答ありがとうございます。  %lf,%le,%lgのいずれでも正常に作動しました。  %lfのlはlong型変数のことでしょうか?

その他の回答 (3)

  • jacta
  • ベストアンサー率26% (845/3158)
回答No.4

誤動作の原因についてはすでに回答がでているようですので、scanfの書式指定について書きたいと思います。 まず、"%lf"や"%lg"などの'l'についてですが、これは実引数がdoubleへのポインタであることを意味しています。ちなみにlong doubleの場合は'l'の代わりに'L'を付けて"%Lf"のようにします。そして、何も付けない"%f"や"%g"の場合はfloatへのポインタを意味します。 今回の場合、"%e"や"%g"のように、'l'も'L'も付けずに使ったために、実引数がfloatへのポインタと解釈されたことが原因で誤動作したようです。 なお、scanfの場合は、"%f"、"%e"、"%g"、"%E"、"%G"(C99の場合は"%a"や"%A"も)すべて同じ意味になります。これらはprintfの書式指定との対象性のために用意されているだけです。 さて、printfの書式指定ですが、scanfのものとは似ていますが、細かい点ではまったく別のものです。printfの場合、実引数はポインタではなく値そのものを渡しますが、このとき既定の実引数拡張という型変換が行われます。具体的には、int以下の整数はintに、double以下の浮動小数点数はdoubleに変換されます。つまり、floatを渡したつもりでも勝手にdoubleになってしまうわけです。そのため、floatでもdoubleでも、"%f"や"%g"のように'l'は必要ありません(付けてはいけません)。ただし、余りにも間違えて'l'を付ける人が多かったために、C99からは"%lf"や"%lg"のように書くこともできる仕様に変更されています。

eliteyoshi
質問者

お礼

丁寧に説明して頂いてありがとうございます。 結局の所、このような質問をしてしまったのは僕の勉強不足のようです。ご親切な回答を頂いてとても勉強になりました。

  • BLUEPIXY
  • ベストアンサー率50% (3003/5914)
回答No.3

>正常な結果が出ました。 すみません、指数部分が3桁でも大丈夫なようです。 どうも原因は別のところにあるようです。 ウチでは >球の半径(cm)を入力して下さい: 1.00000e+001 >球の半径=2.66182e-314 (cm) 球の体積= 0.00000e+00 (cm^3) が再現しませんでした。 結局#1様の回答で解決ということだと思われます。お騒がせしました。

eliteyoshi
質問者

お礼

何度もご回答ありがとうございます。 何も問題ないということで安心しました。

  • BLUEPIXY
  • ベストアンサー率50% (3003/5914)
回答No.2

scanfで受け付ける指数表現は、 printfで出力されるモノと同じものです。 なので、指数表現は、「2桁」でなければなりません。 1.00007e+002 -1.71005e-001 は 1.00007e+02 -1.71005e-01 のように入力する必要があります

eliteyoshi
質問者

お礼

 ご回答ありがとうございます。  指数表現は、「2桁」でなければならないとのことですが、質問のプログラムで 1.00007e+002 -1.71005e-001 を入力したら正常な結果が出ました。  これからファイル入力のプログラムを作るのですが、入力ファイルの数値の指数表現がすべて「3桁」なのです。「3桁」で問題あるならどうすればよいのでしょうか。