| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 897 人关注过本帖
标题:单精度变量的问题
只看楼主 加入收藏
feixiangma16
Rank: 2
等 级:论坛游民
帖 子:7
专家分:29
注 册:2009-10-29
结帖率:0
收藏
已结贴  问题点数:20 回复次数:9 
单精度变量的问题
简单的说就是两个单精度的数据0.0203和10000相乘结果为什么是203.000009呢,这个9是从哪来的。这个问题让我很苦恼啊。求各位帮忙解决一下。程序如下
#include <stdio.h>
void main()
{
    float a,b;
    a=0.0203;
    b=10000;
    printf("%f\n",a*b);
}
超简单的程序。哎。
搜索更多相关主题的帖子: include 
2011-03-19 14:21
panfengyin
Rank: 1
等 级:新手上路
帖 子:2
专家分:4
注 册:2011-3-19
收藏
得分:4 
en ``因为单精度小数点后面有6位,而那个9是随机的出来的数
2011-03-19 15:33
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:528
帖 子:9024
专家分:54030
注 册:2011-1-18
收藏
得分:4 
    float a,b;
    a=0.0203;           // a==0.0203000009059906005859375
    b=10000;            // b==10000.0
    printf("%f\n",a*b); // a*b==203.0000152587890625, double(a*b)==203.000009059906005859375
2011-03-19 15:40
瓦药墙
Rank: 7Rank: 7Rank: 7
等 级:黑侠
帖 子:218
专家分:556
注 册:2009-9-16
收藏
得分:4 
#include <stdio.h>
void main()
{
    double a,b;
    a=0.0203;
    b=10000;
    printf("%lf\n",a*b);
}
2011-03-19 15:40
瓦药墙
Rank: 7Rank: 7Rank: 7
等 级:黑侠
帖 子:218
专家分:556
注 册:2009-9-16
收藏
得分:0 
a=0.0203   你没加f后缀, 它是double型

而你用float型输出, 那个..结果不准确
2011-03-19 15:42
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:528
帖 子:9024
专家分:54030
注 册:2011-1-18
收藏
得分:0 
en ``因为单精度小数点后面有6位,而那个9是随机的出来的数
----- 如果是“随机的出来的数 ”那你每次运行时输出应该不一样,但从理论上就是不可能的。
2011-03-19 15:42
瓦药墙
Rank: 7Rank: 7Rank: 7
等 级:黑侠
帖 子:218
专家分:556
注 册:2009-9-16
收藏
得分:0 
float精度不够, 有误差..
2011-03-19 15:42
刘定邦
Rank: 10Rank: 10Rank: 10
等 级:青峰侠
帖 子:687
专家分:1570
注 册:2010-9-21
收藏
得分:4 
要精度高。那就用又精度吧。。
2011-03-19 16:05
刘定邦
Rank: 10Rank: 10Rank: 10
等 级:青峰侠
帖 子:687
专家分:1570
注 册:2010-9-21
收藏
得分:0 
双。。
2011-03-19 16:05
weiwei555
Rank: 5Rank: 5
来 自:中国
等 级:职业侠客
帖 子:179
专家分:323
注 册:2011-3-4
收藏
得分:4 
用双精度吧
2011-03-20 12:10
快速回复:单精度变量的问题
数据加载中...
 
   



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

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