gpt4 book ai didi

C++ 精度使用 long long 和 double

转载 作者:太空狗 更新时间:2023-10-29 20:37:09 24 4
gpt4 key购买 nike

我正在试验 C++。我编写了一个简单的函数,它使用非常大的数字来计算三角形的面积。

我将两个大数字传递给函数,然后从一个单独的函数 getValue() 返回一个不同方程式的单独值。我很好奇为什么当我将 1 放在括号外的线上时,就像这样:

return (long long)(a - b / 2.0) + b + 1;

我得到值 9007200509008001

当我将 1 放在括号内时,如下所示:

return (long long)(a - b / 2.0 + 1) + b;

我得到 9007200509008000

第二个值比第一个小一个,即使计算结果应该相同。

#include <iostream>

double triangleArea(int b, int h)
{
long long bh = (long long)b * h;
return 0.5 * bh;
}

long long getValue()
{
int deltaY = 18014400;
int deltaX = 1000000000;

long b = deltaY + deltaX + 1600;
double a = triangleArea(deltaX, deltaY);
return (long long)(a - b / 2.0) + b + 1;
}

int main(int argc, char **argv)
{
std::cout << getValue() << std::endl;
}

我确信答案对某些人来说可能是显而易见的,但我无法理解。谁能解释一下?

最佳答案

当您除以 2.0 时,您可以隐式转换为 double。 double 限制为大约 15 位十进制数字。所以第 16th 位会发生什么是完美定义的,但可能不是您所期望的。

如果您需要准确性,请尝试使用long longunsigned long long 并仔细控制您没有溢出。如果还不够,您将不得不使用多精度算术(例如 GMP )。因为一旦您使用双 float ,您的精度就会被限制为 53 位二进制数字,或大约 15-16 位十进制数字。

关于C++ 精度使用 long long 和 double,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35742140/

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