質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

Q&A

解決済

2回答

547閲覧

実数を二進数に変更するときの誤差について

kamecha

総合スコア41

C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

0グッド

0クリップ

投稿2017/09/11 07:22

###前提
c言語初心者の高校生です。
書籍で勉強しているため、そこで分からなかった事を質問します。

###問題
float型の変数を0.0~0.01ずつ増やしていく様子と、int型の変数を0~100までインクリメントした値を100.0で割った値を求める様子を、横に並べて表示するプログラムを作成せよ。
また、0.0~1.0まで0.01ずつ増やした値すべての累計を求めるプログラムを作成せよ。

###該当のコード

lang

1#include <stdio.h> 2 3int main(void){ 4 double k, l; //累計 5 int i; 6 float x; 7 8 for(i = 0, x = 0.0; i <= 100, x <= 1.0; i++, x += 0.01){ 9 printf("x = %f", x); 10 printf(" x = %f\n", i / 100.0); 11 12 k += x; 13 l += i / 100.0; 14 } 15 putchar('\n'); 16 17 puts("Cumulative!"); 18 printf("x = %f", k); printf(" x = %f\n", l); 19 20 return 0; 21} 22

###疑問点
累計の「double」を「float」にすると、
累計(l)の方が
50.500000 → 50.500004
になるのですが、
これが何故だか分かりません。
実数を二進数に直すときに誤差がでるのは、分かるのですが
「double」や「float」で何がどう違うのかがよく分かりません。

###補足情報
書籍 : 新明解C言語 入門編
返信遅れるかもしれません

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

浮動小数点の詳しい説明を書いたサイトを見つけました。「浮動小数点型と誤差」をご覧頂けると良いと思います。
詳しく説明しています。

投稿2017/09/11 07:44

diracpaul

総合スコア157

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

kamecha

2017/09/11 07:50

見させていただきました。 図表が分かりやすかったです。
guest

0

ベストアンサー

floatdoubleでは、値の精度が違ってきます。多くの環境(IEEE 754を採用した環境)では、

  • float…仮数部は2進法で24ビット→10進法で7桁ちょっと
  • double…仮数部は2進法で53ビット→10進法で16桁弱

というようになっています。floatで計算したほうは、「50.500004」なので、8桁目で値がずれていることがわかります。

投稿2017/09/11 07:29

maisumakun

総合スコア145183

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

kamecha

2017/09/11 07:49

double型の方がfloat型より精度が高いため、double型にしたときに誤差が起きにくい、 ということですか?
maisumakun

2017/09/11 07:52

そうですね。ただ、doubleもfloatも1の位以下も2進法で処理するので、0.1すら正確に表せない、という意味では共通です。
kamecha

2017/09/11 13:39

なるほど! 有り難うございます。 二進数の弱点が分かった気がします
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問