我的教科书中有以下算法,它应该计算精确到3位数的数字的自然对数。
#include <iostream>
#include <cmath>
double logN(double a, double li, double ls)
{
if(a == 1)
return 0;
else if(fabs(li - ls) < 0.0001)
return (li + ls) / 2;
else if((exp(li) - a) * (exp((li + ls) / 2) - a) < 0)
return logN(a, li, (li + ls) / 2);
else
return logN(a, (li + ls) / 2, ls);
}
int main()
{
std::cout << logN(3, 0, 3) << std::endl;
std::cout << logN(4, 0, 4) << std::endl;
std::cout << logN(5, 0, 5) << std::endl;
return 0;
}
这句话对我来说不对:
else if(fabs(li - ls) < 0.0001)
例如,如果我有两个数字:0.9992
和0.9996
。两个数字的前3个数字相等,但它们之间的差异为0.0004
,大于0.0001
,因此测试将失败。我错过了什么?
答案 0 :(得分:1)
这需要(li + ls) / 2
才能正常工作。
例如:
0.999 - 0.9981 = 0.0009 < 0.001
但:
(0.999 + 0.9981) / 2 = 0.99855
另一方面:
(0.9999 + 0.9998) / 2 = 0.99985
当四舍五入到第三位时,最多为1。