标题:用scanf输入float型的变量的时候精度缺失的现象
只看楼主
ming_fox
Rank: 1
等 级:新手上路
帖 子:5
专家分:0
注 册:2010-8-14
结帖率:50%
已结贴  问题点数:10 回复次数:7 
用scanf输入float型的变量的时候精度缺失的现象
大家好,我最近在学习C语言,作为一个初学者有些不太明白的地方向各位高手请教一下。

我写了一段代码,想用scanf函数输入一个float的数值,做计算。但是在输入过程中发现
我输入的值有的时候会出现误差,我怀疑是精度的问题,但是不知道怎么解决这个问题。
请大家指点一下。具体情况如下。

【code】
    .......
    float money;
    printf("Enter a money:");
    scanf("%f",&money);
    printf("money:%f\n",money);
    .......
当程序运行起来,出现Enter a money:之后,我输入123.49之后回车。
在屏幕上显示为:money:123.489998
我很诧异为什么少了那么一点,而且换个数字的话差的值就变了,不过变动
的范围是在0.000001到0.000003之间。


请问谁知道这是个什么情况,怎么才能不丢失精度,输入什么就用什么去操作呢,
有知道的朋友能指点下么,谢谢了~
搜索更多相关主题的帖子: float 变量 精度 scanf 缺失 
2010-08-14 16:17
ming_fox
Rank: 1
等 级:新手上路
帖 子:5
专家分:0
注 册:2010-8-14
得分:0 
有人在没?有人知道这个问题是怎么回事么,呵呵。希望有人能指点指点,谢谢.
2010-08-14 16:36
康冬亮
Rank: 1
来 自:成都
等 级:新手上路
帖 子:32
专家分:2
注 册:2010-8-14
得分:2 
这是因为系统在储存浮点型时是使用二进制储存的,在二进制转成十进制时有误差。
2010-08-14 22:52
Rexfield
Rank: 6Rank: 6
来 自:幻想乡
等 级:侠之大者
威 望:1
帖 子:240
专家分:484
注 册:2010-7-28
得分:2 
以下是引用康冬亮在2010-8-14 22:52:07的发言:

这是因为系统在储存浮点型时是使用二进制储存的,在二进制转成十进制时有误差。
貌似是十进制转二进制时有误差。

小数位 10->2 时,每个数乘二取整,直到余 0 。
但是大多情况都会出现无限循环,所以,就得舍掉一部分。
然后移码的时候又可能舍掉。。。

If you're not failing every now and again, it's a sign you're not doing anything very innovative.
2010-08-14 23:01
crazysand
Rank: 2
等 级:论坛游民
帖 子:3
专家分:24
注 册:2010-8-14
得分:2 
printf("money:%。2f\n",money);
2010-08-14 23:04
liuzhengshen
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:83
专家分:141
注 册:2010-4-23
得分:2 
楼主:实型数据是不能百分百的准确存储
2010-08-14 23:54
jack10141
Rank: 11Rank: 11Rank: 11Rank: 11
来 自:陕西西安
等 级:小飞侠
威 望:6
帖 子:706
专家分:2271
注 册:2010-8-10
得分:2 
回复 楼主 ming_fox
这个称之为实型数据的舍入误差,在编程的过程中只要用到实型数据,就会存在啊

Coding就像一盒巧克力,你永远不会知道你会遇到什么BUG
别跟我说你是不能的,这让我愤怒,因为这侮辱了你的智慧
2010-08-15 01:36
康冬亮
Rank: 1
来 自:成都
等 级:新手上路
帖 子:32
专家分:2
注 册:2010-8-14
得分:0 
回复 4楼 Rexfield
不好意思   写错了   应该是十进制转二进制有误差
2010-08-15 02:19



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-315687-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.218777 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved