HDUOJ1042N!(Java大数)

HDUOJ1042N!
Problem Description
Given an integer N(0 ≤ N ≤ 10000), your task is to calculate N!

Input
One N in one line, process to the end of file.

Output
For each N, output N! in one line.

第一次写了一个在while外面的数组就直接存好了范围内每个数的阶乘但是wa了
然后就换了一个方法

import java.io.BufferedInputStream;
import java.util.*;
import java.math.*;
public class Main {

    public static void main(String[] args) {
        Scanner in = new Scanner(new BufferedInputStream(System.in));
        int n;
//      BigInteger a[] = new BigInteger[10010];
//      a[0] = BigInteger.valueOf(1);
//      for(int i = 1; i <= 10000; i++)
//      {
//          a[i] = a[i-1].multiply(BigInteger.valueOf(i)); 
//      }
        while(in.hasNext())
        {
            n = in.nextInt();
            BigDecimal ans = fun(n);
            System.out.println(ans);

        }
    }
    public static BigDecimal fun(int n)
    {
        BigDecimal ans = BigDecimal.valueOf(1);
        for(int i = 1; i <= n; i++)
        {
            ans = ans.multiply(BigDecimal.valueOf(i));
        }
        return ans;
    }

}

猜你喜欢

转载自blog.csdn.net/wuswi0412/article/details/80033706