#include <cstdio>
#include <cstring>
const int maxn = 3000;
int a[maxn];
int main(){
memset(a, 0, sizeof(a));
a[0] = 1;
int n = 0;
scanf("%d", &n);
for (int i = 2; i <= n; ++i){
int c = 0;
for (int j = 0; j < maxn; ++j){
int tmp = a[j] * i + c;
c = tmp / 10;
a[j] = tmp % 10;
}
}
int i = maxn - 1;
while (a[i] == 0){
--i;
}
while (i >= 0){
printf("%d", a[i--]);
}
printf("\n");
return 0;
}算法竞赛入门经典 5.2.2高精度阶乘
本文介绍了一种使用C语言实现大数乘法的方法。通过数组存储大数,并利用基本的乘法原理进行逐位相乘,最终得到乘法结果。文章详细展示了如何避免整数溢出问题,并提供了完整的代码示例。

被折叠的 条评论
为什么被折叠?



