问答详情
源自:3-1 什么是运算符

(a+b)-b答案为什么不是12.3 而是12.29999999997 是小数点问题吗?

public class HelloWorld{

    public static void main(String[] args) {

double a=12.3;

int b=24;

double sum=(a+b)-b;

System.out.println("两数之和为:"+sum);

}

}


提问者:慕无忌0479860 2021-06-15 00:03

个回答

  • weixin_慕桂英0467466
    2021-06-15 21:26:15

    我们对浮点数进行乘除运算的时候计算机会把十进制转化为二进制进行计算,然后再把结果转为十进制,在转为十进制的时候出现误差。可以这样改

    public class HelloWorld {
        public static void main(String[] args) {
            double a = 12.3;
            int b = 24;
            double sum = (a + b) - b;
            System.out.printf("两数之和为:%.3f", sum);
        }
    }