假设a,b是_int64变量。需要在高精度的80位浮点数中计算sqrt((long double)a)*sqrt((long double)b)。
举例说明。(__int64)(sqrt((long double)a)*sqrt((long double)a) + 0.5) != a在很多情况下都是应该的。
哪种win32 C/C++编译器可以管理80位浮点运算?
发布于 2011-08-11 04:03:11
你可能不应该使用浮点来取整数的平方根,特别是long double,它的支持很差,在某些系统上可能有一个近似(不准确)的sqrtl。取而代之的是整数平方根算法。
发布于 2011-08-11 03:21:28
您确定sqrt()对long double有效吗?
至少在某些环境中,sqrt()用于双精度,sqrtf()用于浮点型,sqrtl()用于长双精度。
发布于 2011-08-11 03:19:35
Embarcadero的C++Builder将处理80位浮点。使用long double类型或(从Delphi导入的) Extnded类型。它们是一样的。
https://stackoverflow.com/questions/7016431
复制相似问题