このプログラムは球の体積を求めるものです。
#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)
というふうに正常な出力結果が得られません。どのようにすればこのプログラムが正常に動くのでしょうか。
ご存知の方、お手数ですが教えてください。よろしくお願いします。
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"のように書くこともできる仕様に変更されています。
丁寧に説明して頂いてありがとうございます。
結局の所、このような質問をしてしまったのは僕の勉強不足のようです。ご親切な回答を頂いてとても勉強になりました。
No.3
- 回答日時:
>正常な結果が出ました。
すみません、指数部分が3桁でも大丈夫なようです。
どうも原因は別のところにあるようです。
ウチでは
>球の半径(cm)を入力して下さい: 1.00000e+001
>球の半径=2.66182e-314 (cm) 球の体積= 0.00000e+00 (cm^3)
が再現しませんでした。
結局#1様の回答で解決ということだと思われます。お騒がせしました。
No.2
- 回答日時:
scanfで受け付ける指数表現は、
printfで出力されるモノと同じものです。
なので、指数表現は、「2桁」でなければなりません。
1.00007e+002
-1.71005e-001
は
1.00007e+02
-1.71005e-01
のように入力する必要があります
ご回答ありがとうございます。
指数表現は、「2桁」でなければならないとのことですが、質問のプログラムで
1.00007e+002
-1.71005e-001
を入力したら正常な結果が出ました。
これからファイル入力のプログラムを作るのですが、入力ファイルの数値の指数表現がすべて「3桁」なのです。「3桁」で問題あるならどうすればよいのでしょうか。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- C言語・C++・C# C言語(構造体) 3 2022/07/05 20:08
- C言語・C++・C# 10個の実数に対する降順ソート結果を出力するプログラムを作りたいのですが、以下のプログラムをどう直せ 1 2022/07/09 22:16
- 数学 球の中心が正三角形の3辺をたどって1周したとき、球が通過してできた立体の体積を求めなさい。 1 2022/06/23 20:35
- C言語・C++・C# LU分解法のピボット選択機能実装について(C言語・gcc-9) 1 2022/07/22 15:20
- 数学 半径6の円Kを底面とする半球がある。半球の底面に平行な平面が半球と交わっており、交わりの円Lの半径は 6 2022/06/24 06:34
- C言語・C++・C# 至急お願いします。プログラミングの問題です。 最初に正の整数nの入力を受け付け、次に分数の分子と分母 3 2022/07/19 17:09
- 物理学 電磁気の問題で質問です。 2 2022/07/16 17:41
- C言語・C++・C# 至急教えてください!プログラミングの問題です。 割られる整数と割る整数を受け取って、商と余りを出力す 3 2022/07/05 10:23
- C言語・C++・C# 至急教えてください。プログラミングの問題です。 最初に正の整数nの入力を受け付け、次に分数の分子と分 1 2022/07/19 17:03
- C言語・C++・C# 至急教えてください。プログラミングの問題です。 malloc関数を使ってください!お願いします! 最 1 2022/07/21 09:28
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
プログラムでの数字につく”f”の...
-
C 開放してるのにエラー(doubl...
-
C言語 関数プロトタイプ宣言の...
-
数値を指数部と仮数部に分離したい
-
学校の課題で2次方程式のプログ...
-
関数におけるif文とreturn文に...
-
C言語を実行すると-infが出てき...
-
float型とdouble型の変数の違い...
-
C言語で表記についの質問です
-
指数の表示
-
2分法で方程式の複数の解を自...
-
doubleは常に%lfとするべきなのか
-
物体が往復する動きを作りたい
-
C言語で内積、、、わかりません。
-
c言語のコンパイルエラー canno...
-
C言語のpow関数の不具合
-
処理時間計測
-
float?数字の後にLがつくもの
-
「割り算」 と 「分数の掛け算」
-
C++標準ライブラリィーのcomple...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
プログラムでの数字につく”f”の...
-
float型とdouble型の変数の違い...
-
doubleの変数にintとintの割り...
-
C言語を実行すると-infが出てき...
-
C 開放してるのにエラー(doubl...
-
至急です! マクロ定義で #defi...
-
c言語で、繰り返し文の中で、0....
-
関数におけるif文とreturn文に...
-
C言語 関数プロトタイプ宣言の...
-
C言語初心者 構造体 課題について
-
C言語の型による処理速度の違い
-
Cで3乗根を求める方法
-
C言語で-23乗を取り扱うには
-
2分法で方程式の複数の解を自...
-
doubleは常に%lfとするべきなのか
-
c言語のコンパイルエラー canno...
-
C言語で直角三角形の斜辺を求め...
-
C言語のプログラムで#include<m...
-
int とdoubleの比較
-
C++で外積
おすすめ情報