搜索
编程论坛
→
开发语言
→
『 C语言论坛 』
→ 单精度变量的问题
标题:
单精度变量的问题
只看楼主
feixiangma16
等 级:
论坛游民
帖 子: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
等 级:
新手上路
帖 子:2
专家分:4
注 册:2011-3-19
第
2
楼
得分:4
en ``因为单精度小数点后面有6位,而那个9是随机的出来的数
2011-03-19 15:33
rjsp
等 级:
版主
威 望:
507
帖 子:8890
专家分:53117
注 册:2011-1-18
第
3
楼
得分: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
瓦药墙
等 级:
黑侠
帖 子:218
专家分:556
注 册:2009-9-16
第
4
楼
得分:4
#include <stdio.h>
void main()
{
double a,b;
a=0.0203;
b=10000;
printf("%lf\n",a*b);
}
2011-03-19 15:40
瓦药墙
等 级:
黑侠
帖 子:218
专家分:556
注 册:2009-9-16
第
5
楼
得分:0
a=0.0203 你没加f后缀, 它是double型
而你用float型输出, 那个..结果不准确
2011-03-19 15:42
rjsp
等 级:
版主
威 望:
507
帖 子:8890
专家分:53117
注 册:2011-1-18
第
6
楼
得分:0
en ``因为单精度小数点后面有6位,而那个9是随机的出来的数
----- 如果是“随机的出来的数 ”那你每次运行时输出应该不一样,但从理论上就是不可能的。
2011-03-19 15:42
瓦药墙
等 级:
黑侠
帖 子:218
专家分:556
注 册:2009-9-16
第
7
楼
得分:0
float精度不够, 有误差..
2011-03-19 15:42
刘定邦
等 级:
青峰侠
帖 子:687
专家分:1570
注 册:2010-9-21
第
8
楼
得分:4
要精度高。那就用又精度吧。。
2011-03-19 16:05
刘定邦
等 级:
青峰侠
帖 子:687
专家分:1570
注 册:2010-9-21
第
9
楼
得分:0
双。。
2011-03-19 16:05
weiwei555
来 自:中国
等 级:
职业侠客
帖 子:179
专家分:323
注 册:2011-3-4
第
10
楼
得分:4
用双精度吧
2011-03-20 12:10
10
1/1页
1
参与讨论请移步原网站贴子:
https://bbs.bccn.net/thread-334132-1-1.html
关于我们
|
广告合作
|
编程中国
|
清除Cookies
|
TOP
|
手机版
编程中国
版权所有,并保留所有权利。
Powered by
Discuz
, Processed in 0.116403 second(s), 8 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved