JAVA中可以有兩個方法處理這個問題
第一種方法就是BigInteger類,用這個類可以很方便的求出非常大的數.以求100!為例
import java.io.*;
import java.math.BigInteger;
public class calc {
public static void main(String[] args) throws IOException{
BigInteger s = BigInteger.valueOf(1);
for(int i=1;i<=100;i++){
s = s.multiply(BigInteger.valueOf(i));
System.out.println(s);
}
}
}
第二種方法是,把求的值放在足夠大的數組中
import java.util.*;
public class calc2{
public static void main(String[] args) throws Exception{
int[] data = new int[1000];
int num = 1;
data[1] = 1;
System.out.println("用數組解決java大數計算問題");
System.out.println("求一個整數的階乘,請輸入一個整數:");
Scanner input = new Scanner(System.in);
int n = input.nextInt();
for(int i=1;i<=n;i++){
for(int j=1;j<=num;j++){
data[j] = data[j] * i;
}
for(int j=1;j<num;j++){
if(data[j] >= 10){
data[j+1]+=data[j]/10;
data[j]=data[j]%10;
}
}
while(data[num]>=10){
num++;
data[num]+=data[num-1]/10;
data[num-1]=data[num-1]%10;
}
}
System.out.print(n+"!=");
for(int t=num;t>=1;t–){
System.out.print(data[t]);
}
}
}
作者“coldg的博客”