c语言float代码,[求助]float

[求助]float

有问题请教

下面是个实型变量的输出例题:

main()

{

float x,y;

double z;

x=123456789.123;

y=-12345.123;

z=-123456789.123;

printf("x=%f,y=%f,z=%f\n",x,y,z);

}

输出结果为:

x=123456792.000000,y=-12345.123000,

z=-123456789.123000

就是这个题啊输出结果我不太明白,说XY的输出结果吧XY是单精度的,有效值位数为6位到7位。

为什么后面的有这么多位啊?

搜索更多相关的解决方案:

float  单精度  变量  输出

----------------解决方案--------------------------------------------------------

小数一般保留6位~7位(最后输出结果)   单精度有效位最多7位(储存的基数),显然x 7位以后的数不准确了

----------------解决方案--------------------------------------------------------

以下是援引谭浩强 <>第76页的文字:

"%f不指定字段宽度,由系统自动指定,使整数部分全部如数输出,并输出6位小数.应当注意,并非全部数字都是有效数字.单精度实数的有效位数一般为7位"

x=123456792.000000,y=-12345.123000,

z=-123456789.123000 "只有前7位数字是有效数字.千万不要以为打印出来的数字都是有效数字"

----------------解决方案--------------------------------------------------------

以下是引用haishanglang在2006-3-21 22:08:00的发言:

以下是援引谭浩强 <>第76页的文字:

"%f不指定字段宽度,由系统自动指定,使整数部分全部如数输出,并输出6位小数.应当注意,并非全部数字都是有效数字.单精度实数的有效位数一般为7位"

x=123456792.000000,y=-12345.123000,

z=-123456789.123000  "只有前7位数字是有效数字.千万不要以为打印出来的数字都是有效数字"

----------------解决方案--------------------------------------------------------

各位大哥谢谢了

也就是说保留的7位才是输出结果,后面的是不是随便瞎写也可以啊!

后面的并无实际意义是不是?

----------------解决方案--------------------------------------------------------

是这样的哦

----------------解决方案--------------------------------------------------------

不用我说了...

----------------解决方案--------------------------------------------------------

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值