

No.2ベストアンサー
- 回答日時:
一言で言えば、仕様です。
ふたつの側面がありますが。
まずひとつ。Cでは、int 型通しの演算の結果は、int です。
ですから、 a / b の計算結果は、int になります。
次、
ans = a / b ;
は、一見、ans が float なので、float 型の結果が得られそうですが、右辺が int なので、float = int という代入が発生しているに過ぎません。
このため、
a / b の結果が(int として) 0
ans = 0;
という代入が行われて、ans の結果はゼロになります。
これを防ぐためには、a か b のいずれかを float にしてやればいいわけで、
ans = (float)a / b;
ans = a / (float)b;
のいずれも答えは、0.5 になります。
これは、int と float の演算は、「int の方を float に変換した上で計算して、結果は float」という決まりだからです。
ans = (float)a / (float)b;
でも同じですね。
ただ、
ans = (float)(a / b);
では結果はやはりゼロになります。
というか、この場合は、 ans = a / b; と同じことです。
あと、普通の場合、float を使うよりは、double を使った方が良いと思います。
この回答へのお礼
お礼日時:2007/06/18 20:12
>一見、ans が float なので、float 型の結果が得られそうですが、右辺が int なので、float = int という代入が発生しているに過ぎません
よく理解できました。
ありがとうございます。
>ans が float なので、float 型の結果が得られそうですが
そうなると思っていました。
No.1
- 回答日時:
> 仕様ですか?
仕様です。
小学校低学年で習ったことを思い出してみましょう。
64 ÷ 128 = 0 ... 64
ですね。
int型は整数型ですので、演算結果も整数しか扱えません。整数を浮動小数点型の変数(今回であればans)に代入したとしても、元々持っていない情報が補完されるわけではありません。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
「指定されたキャストは有効で...
-
#define _CRT_SECURE_NO_WARNIN...
-
C言語で分からないところがあり...
-
最早開始時間と最遅完了時刻を...
-
int型とfloat型の演算結果
-
【C++】関数ポインタの使い方
-
商と剰余を同時に求める(C言語)
-
fprintfでの文字化け
-
if と配列の組み合わせ
-
複数桁10進数の*桁目だけを抽出...
-
read関数をノンブロッキングで...
-
配列v2を逆順にしてv1に格納す...
-
画素数の計算について
-
VB.NET DLL 参照型String読込み
-
c言語のenum
-
フィボナッチ数列のプログラム
-
(マルチスレッド)_beginthrea...
-
int型の割算
-
ナップサック問題の解法(完全...
-
C言語 巡回セールスマン問題 2-...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
複数桁10進数の*桁目だけを抽出...
-
C言語での引数の省略方法
-
「指定されたキャストは有効で...
-
#define _CRT_SECURE_NO_WARNIN...
-
C言語 エラーの原因がわからな...
-
【C++】関数ポインタの使い方
-
ラップ関数とはどんなものですか?
-
エラー 添字が付けられた値が、...
-
acceptをalarmでタイムアウトさ...
-
if と配列の組み合わせ
-
式は定数値が必要です」という...
-
「{ } で囲むだけ」は正しい?
-
(マルチスレッド)_beginthrea...
-
構造体の勉強中です 合計点の高...
-
数字列を3桁ごとにカンマで区切...
-
return 1L
-
std::set<int> で、ある値が何...
-
C#のコンパイルエラーCS0120に...
-
比較回数と交換回数表示について
-
C言語で分からないところがあり...
おすすめ情報