gpt4 book ai didi

c++ - 带 float 的 std::cout

转载 作者:塔克拉玛干 更新时间:2023-11-02 23:26:49 25 4
gpt4 key购买 nike

我正在使用 visual studio 2015 打印两个 float :

double d1 = 1.5;
double d2 = 123456.789;

std::cout << "value1: " << d1 << std::endl;
std::cout << "value2: " << d2 << std::endl;

std::cout << "maximum number of significant decimal digits (value1): " << -std::log10(std::nextafter(d1, std::numeric_limits<double>::max()) - d1) << std::endl;
std::cout << "maximum number of significant decimal digits (value2): " << -std::log10(std::nextafter(d2, std::numeric_limits<double>::max()) - d2) << std::endl;

这将打印以下内容:

value1: 1.5
value2: 123457
maximum number of significant decimal digits (value1): 15.6536
maximum number of significant decimal digits (value2): 10.8371

为什么 123457 打印出值 123456.789?当在没有 std::setprecision() 的情况下使用 std::cout 时,ANSI C++ 规范是否允许显示任何 float ?

最佳答案

四舍五入是因为 C++ 标准,可以通过编写看到 std::cout<<std::cout.precision();

输出屏幕将显示 6这表明 std::cout 将打印的默认有效数字位数声明是6 .这就是它自动将 float 四舍五入为 6 位数字的原因。

关于c++ - 带 float 的 std::cout,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33854825/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com