51nod 1057 N的阶乘

Posted 8023spz

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了51nod 1057 N的阶乘相关的知识,希望对你有一定的参考价值。

输入N求N的阶乘的准确值。
 

输入

输入N(1 <= N <= 10000)

输出

输出N的阶乘

输入样例

5

输出样例

120
模拟乘法
代码:
#include <iostream>
#include <cstdio>
#include <cmath>
#define MAX 50000
using namespace std;
int n,num[MAX] = {1},c = 1;
int main() {
    scanf("%d",&n);
    for(int i = 2;i <= n;i ++) {
        int d = 0;
        for(int j = 0;j < c;j ++) {
            d += num[j] * i;
            num[j] = d % 10;
            d /= 10;
        }
        while(d) {
            num[c ++] = d % 10;
            d /= 10;
        }
    }
    for(int i = c - 1;i >= 0;i --) {
        printf("%d",num[i]);
    }
}

 

以上是关于51nod 1057 N的阶乘的主要内容,如果未能解决你的问题,请参考以下文章

51NOD 1057 N的阶乘

1057 N的阶乘(51NOD基础题)

51 Nod 1057 N的阶乘Java大数乱搞

51nod 1057 N的阶乘 (大数运算)

N的阶乘(10000) 51 nod——1057 (大数)

1057 N的阶乘(大数运算)