C++关于float和double的有效位数

要探究double和float的有效位数,前提知识点:cout.setf(ios_base::fixed,ios_base::floatfield);
因为c++通常会删除结尾的0,这条语句可以覆盖这种行为;
完整代码如下:

#include<iostream>
using namespace std;
int main()
{
 cout.setf(ios_base::fixed,ios_base::floatfield);
 float tub = 10.0 /3.0;
 double mint = 10.0 / 3.0;
 const float million = 1.0e6;
 cout<<"tub = "<<tub;
 cout<<" a million tubs = "<<million*tub;
 cout<<"\nand ten million tubs=";
 cout<<10* million *tub<<endl;  //float最少有6位有效位 
 cout<<"mint = "<<mint<< " a million mint = ";
 cout<<million *mint <<endl;   //double最少有15位有效位数 
  
 return 0;
}

该代码运行效果图为:在这里插入图片描述
float类型的tub在乘一百万之后出现了精度丢失的现象,而double类型的mint没有出现这种情况。
查阅资料后发现,float类型最多有效位数为6位,double类型为15位,所以出现了如图的精度丢失情况。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值