

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で質問しましょう!
似たような質問が見つかりました
- その他(プログラミング・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を探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・昔のあなたへのアドバイス
- ・字面がカッコいい英単語
- ・許せない心理テスト
- ・歩いた自慢大会
- ・「I love you」 をかっこよく翻訳してみてください
- ・ゆるやかでぃべーと タイムマシンを破壊すべきか。
- ・はじめての旅行はどこに行きましたか?
- ・準・究極の選択
- ・この人頭いいなと思ったエピソード
- ・「それ、メッセージ花火でわざわざ伝えること?」
- ・ゆるやかでぃべーと すべての高校生はアルバイトをするべきだ。
- ・【お題】甲子園での思い出の残し方
- ・【お題】動物のキャッチフレーズ
- ・人生で一番思い出に残ってる靴
- ・これ何て呼びますか Part2
- ・スタッフと宿泊客が全員斜め上を行くホテルのレビュー
- ・あなたが好きな本屋さんを教えてください
- ・かっこよく答えてください!!
- ・一回も披露したことのない豆知識
- ・ショボ短歌会
- ・いちばん失敗した人決定戦
- ・性格悪い人が優勝
- ・最速怪談選手権
- ・限定しりとり
- ・性格いい人が優勝
- ・これ何て呼びますか
- ・チョコミントアイス
- ・単二電池
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・ゴリラ向け動画サイト「ウホウホ動画」にありがちなこと
- ・泣きながら食べたご飯の思い出
- ・一番好きなみそ汁の具材は?
- ・人生で一番お金がなかったとき
- ・カラオケの鉄板ソング
- ・自分用のお土産
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
「指定されたキャストは有効で...
-
C言語での引数の省略方法
-
複数桁10進数の*桁目だけを抽出...
-
実数の整数部,小数部の取得
-
C言語 エラーの原因がわからな...
-
#define _CRT_SECURE_NO_WARNIN...
-
線形補間 2次元テーブル C言語...
-
C言語で分からないところがあり...
-
ラップ関数とはどんなものですか?
-
配列変数のポインターが勝手に...
-
systemの戻り値を取得する方法
-
ColorをRGBで指定する方法
-
C 言語の Gauss Jordan 法について
-
教えてください(丸罰ゲーム)
-
構造体のすべての変数を文字列...
-
ファイルから読みこむ方法
-
if と配列の組み合わせ
-
CStringの配列要素を関数で受け...
-
Listの<Label>と<PictureBox>
-
int型の変数値をバイト列として...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
「指定されたキャストは有効で...
-
C言語での引数の省略方法
-
複数桁10進数の*桁目だけを抽出...
-
#define _CRT_SECURE_NO_WARNIN...
-
C言語 エラーの原因がわからな...
-
ラップ関数とはどんなものですか?
-
【C++】関数ポインタの使い方
-
実数の整数部,小数部の取得
-
read関数をノンブロッキングで...
-
(int *)の意味
-
ColorをRGBで指定する方法
-
std::set<int> で、ある値が何...
-
PowerShellがうまくいかない
-
int16_t の _t は何?
-
「{ } で囲むだけ」は正しい?
-
int型の変数値をバイト列として...
-
商と剰余を同時に求める(C言語)
-
return 1L
-
acceptをalarmでタイムアウトさ...
-
(マルチスレッド)_beginthrea...
おすすめ情報