1. 程式人生 > >double 精度問題

double 精度問題

pin oid port system orm ins class 累加 格子

/**
*相傳國際象棋是古印度舍罕王的宰相達依爾發明的。
*舍罕王十分喜歡,決定讓宰相自己選擇賞賜。
*這位宰相指著8×8共64格的棋盤說:陛下,請您賞給我一些麥子吧,
*在棋盤的第一個格子放1粒,第2格放2粒,第3格放4粒,
*以後每一格都比前一格增加一倍,依此放完棋盤上的64個格子,我就感恩不盡了。
*舍罕王讓人扛來一袋麥子,他要兌現他的許諾。國王能兌現他的許諾嗎?
*/

import java.text.DecimalFormat;
import java.math.*;

public class a{
public static void main(String[] args){
Double a2 = new Double("0");
double a=0L;
long b=0;
for (int i=1; i<=64 ; i++ ){
//計算過程.
b= (long)Math.pow(2, i-1); //2的i-1次方.
a += b ;
a2 +=b ;
System.out.println("第"+i+"格麥子數:"+b+" 累加:"+a);
}
//double 轉成 String
DecimalFormat decimalFormat = new DecimalFormat("#");
System.out.print("\n最終累加結果:");
System.out.println(decimalFormat.format(a));
BigDecimal a1 = new BigDecimal(Double.toString(a));
System.out.println(a1);
System.out.println(new DecimalFormat("0.00").format(a));
System.out.println(new BigDecimal(a+""));

java.text.NumberFormat nf = java.text.NumberFormat.getInstance();
nf.setGroupingUsed(false);
System.out.println(nf.format(a2));
System.out.println(new BigDecimal(Double.toString(a2)));
}
}

double 精度問題