可能重复:
浮点不准确示例
double a = 0.3;
std::cout.precision(20);
std::cout << a << std::endl;
结果:0.2999999999999999889
double a, b;
a = 0.3;
b = 0;
for (char i = 1; i <= 50; i++) {
b = b + a;
};
std::cout.precision(20);
std::cout << b << std::endl;
结果:15.000000000000014211
所以.. 'a' 比它应该的要小。但是如果我们取 'a' 50 次 - 结果会比它应该的要大。
为什么是这样?在这种情况下如何获得正确的结果?