关于使用float类型来存储小数输出出现误差的情况说明及解决办法

最近在使用float类型来存储小数的时候,我发现了一个问题。

就是明明输入的小数位数不多但是输出的时候总是出现有误差,试了很久没试出来。

类似这样:

而出现这种问题的原因,归根结底是因为我使用的是float(下面简称f)类型来存储了学生的成绩。在计算机存储数字时,一般都是会先把数字转化成二进制来进行计算存储,然而一般除了十进制数的整数和0.5的倍数之外的大多小数,在计算机内部存储转化成二进制时,会出现无限循环小数或者无限不循环小数。当我们使用float类型来存储这些小数的时候,往往就会因为f的精确度不够没有办法完全读取这些小数,就会以近似值的形式输出在屏幕上,这就是为什么我一直没有办法正确输出成绩的原因。

那么如何解决这种情况呢?

有两个办法,一个是对f类型的小数在输出的时候就规定好要输出的小数的位数,像这样:

这个时候输出的结果就比较正常

第二个办法就是把f类型换成精确度更高的类型,比如double或者long类型的(但是精确度更高的代价就是要占用更多的内存空间),像这样:

同时输出要匹配对应类型的%_

这样就可以把小数正常存储起来啦。

感谢阅读

给个三连吧~~~

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值