1

printf("%lf\n",-1.0+0.9+0.1);

结果是

0.000000

同时与

cout<<-1.0+0.9+0.1;

结果是

 2.77556e-17

再次,如果我改变

 cout<<0.9+0.1+-1.0;

结果是

 0

为什么这种不同的行为只是简单地反转总和?为什么 2.77556e-17?它是机器 epsilon?为什么我得到它而不是零?

4

1 回答 1

4

std::cout默认情况下,浮点变量类似于标志%g而不是. 为了获得相同的行为,您必须传递给流,例如:%lfprintfstd::fixed

std::cout << std::fixed << 0.9+0.1+-1.0;
于 2014-11-15T14:23:30.313 回答