1

我正在测试一个我想知道的随机公式。在编写代码测试公式后,大多数是正确的,但有些是错误的。然而,我注意到,在我的打印语句中,等式的两边是相等的,但代码说它们不是。

这是代码:

public static void main(String[] args){
        for(int i = 0; i < 100; i++){
            String t = runTest((100-i)/100.0,i/100.0);
            if(t.substring(0, 1).equals("1")) System.err.println(t);
            else System.out.println(t.substring(1));
        }
    }

    private static String runTest(double a, double b){
        double l = (a + b);
        double r = (a*a + b*b + 2*a*b);
        boolean isValid = false;
        if(l != 1) {
            return 1+String.format("%f + %f = %f\tInvalid", a, b, a + b);
        }
        if(l==r){
            isValid = true;
        }

        return 0+String.format("A: %f B: %f LEFT: %f RIGHT: %f RESULT: %s", a, b, l, r, String.valueOf(isValid));
    }

我也尝试将 l 和 r 强制转换为整数,并且 r 返回 0 有时意味着代码认为 r 低于 0。实际上和 print 语句,右侧也是 1。起初我以为它是一个浮点错误,但双方最终都为 1。

你知道为什么会发生这种情况以及我该如何解决这个问题吗?

谢谢。

4

2 回答 2

4

==使用运算符比较浮点数是否相等是不好的做法。

您必须包含一个容差。

final float T = 0.0000001;
if (Math.abs(l - r) < T)
  isValid = true;

修改 T 使其符合您的需要。

于 2015-03-24T20:52:18.750 回答
1

运行这个

public class Test {
public static void main(String[] args){
    for(int i = 0; i < 100; i++){
        String t = runTest((100-i)/100.0,i/100.0);
        if(t.substring(0, 1).equals("1")) System.err.println(t);
        else System.out.println(t.substring(1));
    }
}

private static String runTest(double a, double b){
    double l = (a + b);
    double r = (a*a + b*b + 2*a*b);
    boolean isValid = false;
    if(l != 1) {
        //return 1+String.format("%f + %f = %f\tInvalid", a, b, a + b);
        return  a + ":" + b+ ":" +  a  +  b ;
    }
    if(l==r){
        isValid = true;
    }
    return  a + ":" + b+ ":" +  l + ":" +  r ;
 }

}

所以是的,当格式化为浮点数时它们看起来相等,但它们是双精度数(64 位),这就是您比较它们的方式(因此它们不相等,正如您从我发布的代码的输出中看到的那样)。

于 2015-03-24T20:51:58.490 回答