非常偶然发现了一个精度损失的问题,简单来说:
有表达式: l = i/30 + j/40 + k/25, 求当{i,j,k} = {50,85,27}时l的值,非常easy,用计算器立即能够算出答案为4.8717,可是编写了下面程序来实现:
int i = 50,j = 85, k = 27;
double l = i/30 + j/40 + k/25;
执行后,结果显示4.000000000。
int i = 50,j = 85, k = 27;
double l = i/30.0 + j/40.0 + k/25.0;
版权声明:本文博主原创文章,博客,未经同意不得转载。