标题:而忘返
只看楼主
编程天使
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2008-5-1
 问题点数:0 回复次数:3 
而忘返
是否斯蒂芬
搜索更多相关主题的帖子: 斯蒂芬 
2008-05-01 15:35
编程天使
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2008-5-1
得分:0 
数据存储问题
#include<stdio.h>
void main()
{
    float a,b;
    a=31.1111,b=28.333;
    printf("%f",a-b);
}
运行结果是:59.444099
根据vc++6.0中的默认规定,float型数据有效数字长度为7,我认为结果是:59.4441**,与运行结果不相符,很是迷茫,很想明白31.1111在vc环境下,在内存中是怎么存储的。
望哪位好心高手赐教,非常感激
2008-05-01 15:41
雨中飛燕
Rank: 1
等 级:新手上路
帖 子:765
专家分:0
注 册:2007-10-13
得分:0 
有效数字个数和显示的小数点后数字个数无关

[color=white]
2008-05-01 16:17
moonwalker
Rank: 1
等 级:新手上路
威 望:1
帖 子:909
专家分:2
注 册:2007-3-2
得分:0 
a-b应该是a+b吧?
b只有5位有效数字,所以计算结果不能保证5位有效数字后的精度

“视频教程网”免费提供教学资源
C不限制你的自由!
条件是自己承担滥用自由的恶果!
2008-05-01 16:18



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




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

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