| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1749 人关注过本帖, 1 人收藏
标题:浮点数比较(一直没解决,心里好难受)
取消只看楼主 加入收藏
jingzitakk66
Rank: 1
等 级:新手上路
帖 子:198
专家分:0
注 册:2009-5-1
结帖率:98.68%
收藏(1)
已结贴  问题点数:50 回复次数:3 
浮点数比较(一直没解决,心里好难受)
下面的程序为什么输入0.000001会显示不相等,虽然我知道浮点数比较大小会有很多问题,但0.000001应该在内存中能精确存储啊
请哪位朋友帮解释一下,请从内部存储方式来讲下面的程序为什么会执行出这样的结果
以下是在下的认识:
在IEEE标准中.浮点以23位表示小数,这样的精确度应为0.00000000000000000000001(二进制),共22个0,换算为十进制大约为
0.000000119(十成制),6个0. 以此判断,十进制转为二进制的精确度只能保证在0.000001,5个零,那我输入0.000001应该能精确存储,怎么还会出现下面的问题呢??
#include"stdio.h"
main()
{
    float i;
    scanf("%f",&i);
   
    if(i == 0.000001)
        printf("It's equate to 0.000001");
    else
        printf("It's not equate to 0.000001");
}
搜索更多相关主题的帖子: 点数 
2009-09-03 20:26
jingzitakk66
Rank: 1
等 级:新手上路
帖 子:198
专家分:0
注 册:2009-5-1
收藏
得分:0 
回复 2楼 UserYuH
请问下

[ 本帖最后由 jingzitakk66 于 2009-9-3 21:47 编辑 ]
2009-09-03 21:45
jingzitakk66
Rank: 1
等 级:新手上路
帖 子:198
专家分:0
注 册:2009-5-1
收藏
得分:0 
回复 3楼 forever74
非常感谢,非常清楚,
再请教一个问题,令我更加困惑的,呵呵
判断一个浮点数与零是否相等为什么要用if(i>-0.000001&&i<0.000001)而不用if(i == 0) ???
能举一个用if(i == 0)会出现问题的例子吗?
2009-09-03 22:08
jingzitakk66
Rank: 1
等 级:新手上路
帖 子:198
专家分:0
注 册:2009-5-1
收藏
得分:0 
回复 6楼 forever74
谢谢,明白了,浮点运算真麻烦,幸好我搞嵌入式,呵呵
2009-09-03 22:43
快速回复:浮点数比较(一直没解决,心里好难受)
数据加载中...
 
   



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

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