此函数是否计算精确到3位数的数字的自然对数?

时间:2015-05-22 13:23:24

标签: c++ algorithm floating-point logarithm

我的教科书中有以下算法,它应该计算精确到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.99920.9996。两个数字的前3个数字相等,但它们之间的差异为0.0004,大于0.0001,因此测试将失败。我错过了什么?

1 个答案:

答案 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。