【九度OJ】题目1076:N的阶乘 解题报告

【九度OJ】题目1076:N的阶乘 解题报告

标签(空格分隔): 九度OJ


原题地址:http://ac.jobdu.com/problem.php?pid=1076

题目描述:

输入一个正整数N,输出N的阶乘。

输入:

正整数N(0<=N<=1000)

输出:

输入可能包括多组数据,对于每一组输入数据,输出N的阶乘

样例输入:

4
5
15

样例输出:

24
120
1307674368000

Ways

同样是大整数的题,显然我们仍然使用BigInteger类!这个题的要求时间是3秒,但是Java一般的时间会扩充两秒,最终这个程序花了3250 ms AC.

第一遍出现错误是因为忘了赋值了。

import java.util.*;
import java.math.*;

public class Main{
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        while (scanner.hasNext()) {
            BigInteger n = scanner.nextBigInteger();
            BigInteger answer = BigInteger.ONE;
            BigInteger one = BigInteger.ONE;
            while (n.compareTo(one) > 0) {
                answer = answer.multiply(n);//别忘记赋值
                n = n.subtract(one);
            }
            System.out.println(answer.toString());
        }
    }
}

Date

2017 年 3 月 8 日

posted @ 2017-03-08 20:04  负雪明烛  阅读(31)  评论(0编辑  收藏  举报