[英]Java: Display float with precision of 30
我正在尝试使用某些算法来计算PI,但是主要的事情是以30的精度显示它。我试图以format
等输出字符串。但是似乎double
最大精度是15。是否有任何类或有什么方法可以帮助我吗?
我已经尝试过:
public class Challenge6PI {
public static void main(String[] args){
System.out.format( "%.30f",
Math.log(Math.pow(640320, 3) + 744) / Math.sqrt(163));
}
}
尽管JDK具有BigDecimal
,但是不幸的是您没有.sqrt()
。
这意味着最好的选择是使用apfloat :
final Apfloat f1 = new Apfloat(640320);
final Apfloat f2 = ApfloatMath.pow(f1, 3L);
final Apfloat f3 = f2.add(new Apfloat(744));
final Apfloat f4 = ApfloatMath.sqrt(new Apfloat(163), 1000L);
final Apfloat ret = ApfloatMath.log(f3.divide(f4));
System.out.println(ApfloatMath.round(ret, 30L, RoundingMode.HALF_DOWN));
不过,您使用pi的方法更短;)
System.out.println(ApfloatMath.pi(30L));
我猜Float不支持那么多的精度。 您可以为此使用BigDecimal。
双精度没有那么高的精度。 看一下double类型是如何实现的 。 对于任意精度,请看BigDecimal
例如:
BigDecimal bd = new BigDecimal(22.0/7.0);
df.setMaximumFractionDigits(30);
System.out.println(df.format(bd));
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.