猿问

在Java中使用Double保持精度

在Java中使用Double保持精度

public class doublePrecision {
    public static void main(String[] args) {

        double total = 0;
        total += 5.6;
        total += 5.8;
        System.out.println(total);
    }}

以上代码打印:

11.399999999999

我如何才能把它打印出来(或者可以用作)11.4?


慕容708150
浏览 3175回答 3
3回答

守着一只汪

例如,当您输入一个双数字时,33.33333333333333,您得到的值实际上是最接近可表示的双精度值,确切地说:33.3333333333333285963817615993320941925048828125除以100表示:0.333333333333333285963817615993320941925048828125它也不能表示为双精度数字,因此再次将其舍入到最接近的可表示值,即:0.3333333333333332593184650249895639717578887939453125输出此值时,它将被舍入。再一次到17位小数,给出:0.33333333333333326

拉风的咖菲猫

如果您只想将值处理为分数,则可以创建一个包含分子和分母字段的分数类。编写加、减、乘和除的方法以及toDouble方法。这样,您可以避免在计算期间浮动。编辑:快速实现,public class Fraction {private int numerator;private int denominator;public Fraction(int n, int d){     numerator = n;     denominator = d;}public double toDouble(){     return ((double)numerator)/((double)denominator);}public static Fraction add(Fraction a, Fraction b){     if(a.denominator != b.denominator){         double aTop = b.denominator * a.numerator;         double bTop = a.denominator * b.numerator;         return new Fraction(aTop + bTop, a.denominator * b.denominator);     }     else{         return new Fraction(a.numerator + b.numerator, a.denominator);     }}public static Fraction divide(Fraction a, Fraction b){     return new Fraction(a.numerator * b.denominator, a.denominator * b.numerator);}public static Fraction multiply(Fraction a, Fraction b){     return new Fraction(a.numerator * b.numerator, a.denominator * b.denominator);}public static Fraction subtract(Fraction a, Fraction b){     if(a.denominator != b.denominator){         double aTop = b.denominator * a.numerator;         double bTop = a.denominator * b.numerator;         return new Fraction(aTop-bTop, a.denominator*b.denominator);     }     else{         return new Fraction(a.numerator - b.numerator, a.denominator);     }}}
随时随地看视频慕课网APP
我要回答