搜索
编程论坛
→
开发语言
→
『 C语言论坛 』
→ C语言float换成double的问题
标题:
C语言float换成double的问题
只看楼主
d1501100204
等 级:
新手上路
帖 子:2
专家分:0
注 册:2015-12-29
结帖率:
0
楼主
已结贴
√
问题点数:16 回复次数:4
C语言float换成double的问题
#include<stdio.h>
void main()
{
float a=123.45;
printf("%f",a);
}
为什么这个程序的执行结果是123.449997而不是123.450000呢?
将float换成double后结果就是123.450000,这是为什么?
搜索更多相关主题的帖子:
double
C语言
2015-12-29 17:52
rjsp
等 级:
版主
威 望:
507
帖 子:8890
专家分:53117
注 册:2011-1-18
第
2
楼
得分:0
float/double 这些叫“浮点数”,不叫“实数”,
在理论上就没有任何有限的资源可以表示无限的状态
float(123.45) 其实表示的是实数 123.4499969482421875
double(123.45) 其实表示的是实数 123.4500000000000028421709430404007434844970703125
收到的鲜花
pycansi
于
2016-01-01 19:46
送鲜花
10朵 附言:好
2015-12-30 10:34
d1501100204
等 级:
新手上路
帖 子:2
专家分:0
注 册:2015-12-29
第
3
楼
得分:0
回复 2楼 rjsp
谢谢
,虽然还是有点模糊
2015-12-30 18:30
crzzhou
等 级:
论坛游民
帖 子:6
专家分:12
注 册:2016-1-1
第
4
楼
得分:8
回复 2楼 rjsp
您好,请问123.4500000002842……后面的非零数字是怎么弄出来的
因为我自己在VC6.0弄不出来=-=
代码如下
#include<stdio.h>
int main(void)
{
float a;
double b;
a = 123.45;
b = 123.45;
printf("a=%.40f\nb=%.40lf\n",a,b);
return 0;
}
结果如下
a=123.4499969482421900000000000000000000000000
b=123.4500000000000000000000000000000000000000
并不是质疑您只是没搞懂
刚学的C如有冒犯请多多包涵
2016-01-01 22:02
rjsp
等 级:
版主
威 望:
507
帖 子:8890
专家分:53117
注 册:2011-1-18
第
5
楼
得分:8
回复 4楼 crzzhou
我是根据浮点数的格式,自己解析的,代码很长就不贴了
或者,你可以用gcc,gcc可以精确指定的长度。
2016-01-04 09:47
5
1/1页
1
参与讨论请移步原网站贴子:
https://bbs.bccn.net/thread-460658-1-1.html
关于我们
|
广告合作
|
编程中国
|
清除Cookies
|
TOP
|
手机版
编程中国
版权所有,并保留所有权利。
Powered by
Discuz
, Processed in 1.522903 second(s), 11 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved