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 を使った方が良いと思います。
>一見、ans が float なので、float 型の結果が得られそうですが、右辺が int なので、float = int という代入が発生しているに過ぎません
よく理解できました。
ありがとうございます。
>ans が float なので、float 型の結果が得られそうですが
そうなると思っていました。
No.1
- 回答日時:
> 仕様ですか?
仕様です。
小学校低学年で習ったことを思い出してみましょう。
64 ÷ 128 = 0 ... 64
ですね。
int型は整数型ですので、演算結果も整数しか扱えません。整数を浮動小数点型の変数(今回であればans)に代入したとしても、元々持っていない情報が補完されるわけではありません。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- その他(プログラミング・Web制作) atcoder python コードへの助言 2 2022/08/12 15:31
- Visual Basic(VBA) InputBoxでキャンセルボタンを押したらファイル自体を閉じたい 3 2022/07/23 17:52
- 数学 paythonを使用した周回積分に関する質問です。 2 2023/02/17 19:09
- C言語・C++・C# 【CASLプログラム】 定数(80と55)を確保し、その和をGR1に、その差をGR2に求めるCASL 1 2022/12/16 01:17
- C言語・C++・C# 宣言する関数の形が決まっている状態で、 str1とstr2の文字列をこの順に引っ付けてstrに保存し 2 2022/05/30 18:21
- 数学 確率の問題(さいころ)の問題で、私の答えが合っていますか? 1 2023/01/26 18:45
- C言語・C++・C# プログラミング c言語 4 2023/03/07 01:05
- C言語・C++・C# 3×3のラテン方陣をつくるプログラムを作成したのですが、(↓) #include <stdio.h> 5 2023/07/10 01:53
- C言語・C++・C# C言語 3 2022/10/04 15:07
- C言語・C++・C# (C言語)めちゃくちゃな値になってしまいます。 5 2022/08/13 11:55
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
C言語
-
#define _CRT_SECURE_NO_WARNIN...
-
C言語 エラーの原因がわからな...
-
比較回数と交換回数表示について
-
複数桁10進数の*桁目だけを抽出...
-
nCmの関数
-
構造体の勉強中です 合計点の高...
-
C言語 配列と関数の練習問題
-
[C言語] 関数を利用する計算
-
実数の整数部,小数部の取得
-
C言語での引数の省略方法
-
数字列を3桁ごとにカンマで区切...
-
アスタリスクでダイヤ型を作る
-
覆面算のプログラムが分かりません
-
C言語の基礎 . 2乗値の差につ...
-
c言語
-
プログラミング
-
【C++】関数ポインタの使い方
-
毎回違う乱数を生成するにはど...
-
if と配列の組み合わせ
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
C言語での引数の省略方法
-
#define _CRT_SECURE_NO_WARNIN...
-
「指定されたキャストは有効で...
-
C言語 配列と関数の練習問題
-
複数桁10進数の*桁目だけを抽出...
-
(int *)の意味
-
if と配列の組み合わせ
-
ラップ関数とはどんなものですか?
-
卒業研究でよく分からないとこ...
-
【C++】関数ポインタの使い方
-
c言語
-
足して100になるような乱数のア...
-
C言語初心者です、、、お助けく...
-
数字列を3桁ごとにカンマで区切...
-
C言語 エラーの原因がわからな...
-
実数の整数部,小数部の取得
-
課題でつまってます・・・
-
商と剰余を同時に求める(C言語)
-
C言語の配列をC++のvectorに高...
-
std::set<int> で、ある値が何...
おすすめ情報