ebinsong 2021-11-30 17:15 采纳率: 100%
浏览 36
已结题

C++浮点型变量精度问题

C++里浮点型变量精度为7,那么整数部分是0的话,算不算一位精度?如果是负数,有效数字就只有6位?
#include<iostream>
using namespace std;
int main()
{
    float f;
    double d;
    f = 0.123456789f;
    d = 123456789.123456789;
    cout << "f = " << f << " d=" << d << endl;
    return 0;
}

运行结果及报错内容

f = 0.123457 d=1.23457e+08
为什么不是f=0.1234568 ?

表头表头
单元格单元格
单元格单元格
单元格单元格
单元格单元格
单元格单元格
单元格单元格

d=1.23457e+08这个结果,有的书上说是 d=1.23457e+008,+08和+008是编译器和系统的区别?
书上说:float f2=-789.012F 若f2=-789.0126F,则f2实际获得的值为-789.013 。既然是7位有效数字,最后那一位6就应该正确显示出来啊?

  • 写回答

4条回答 默认 最新

  • CSDN专家-sinJack 2021-11-30 17:31
    关注

    如果不做特殊的输出语句,默认情况下不论对于单精度还是双精度的形浮型数,
    以Cout<<x形式输出的情况下,c++保留六位有效数字。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(3条)

报告相同问题?

问题事件

  • 系统已结题 12月8日
  • 已采纳回答 11月30日
  • 创建了问题 11月30日

悬赏问题

  • ¥15 itunes恢复数据最后一步发生错误
  • ¥15 关于#windows#的问题:2024年5月15日的win11更新后资源管理器没有地址栏了顶部的地址栏和文件搜索都消失了
  • ¥15 看一下OPENMV原理图有没有错误
  • ¥100 H5网页如何调用微信扫一扫功能?
  • ¥15 讲解电路图,付费求解
  • ¥15 有偿请教计算电磁学的问题涉及到空间中时域UTD和FDTD算法结合的
  • ¥15 vite打包后,页面出现h.createElement is not a function,但本地运行正常
  • ¥15 Java,消息推送配置
  • ¥15 Java计划序号重编制功能,此功能会对所有序号重新排序,排序后不改变前后置关系。
  • ¥15 关于哈夫曼树应用得到一些问题