1. 程式人生 > >Java實現 100!的階乘

Java實現 100!的階乘

res print 方法 原因 color 求階乘 調試 內存 運行

剛學Java循環,求階乘問題的時候,發現求10!可以用int類型存值,

那麽100!呢?用Long? 發現用Long類型,運行輸出的結果是0,這不對啊 ,

到底是什麽原因呢? 用DeBug調試發現,100!數據太大,Long的數據存儲空間8字節不夠用溢出了。
那麽到底用什麽方法來實現100!呢?

如下代碼:

 1 public class Demo01 {
 2     public static void main(String[] args) {
 3         System.out.println(factorial(100));
 4     }
 5 
 6     public static String  factorial(int count) {
 7         BigInteger result = new BigInteger(String.valueOf(1));
 8        for (int i = 1; i <= count; i++) {
 9            BigInteger i_value = new BigInteger(String.valueOf(i));
10            result = result.multiply(i_value);
11        }
12        return result.toString();
13     }
14 }

解決了內存溢出的問題

Java實現 100!的階乘