输入不超过1000的正整数n,输出n!=1*2*3*...*n的精确结果。
样例输入:30
样例输入:30
样例输出:265252859812191058636308480000000
#include<stdio.h>
int ans[40];
int main()
{
memset(ans, 0, sizeof(ans));
int n,c=0;
scanf("%d", &n);
ans[1] = 1;
for (int i = 2; i <= n; i++)
{
for (int j = 0; j < 40; j++)
{
int temp = ans[j] * i + c;
ans[j] = temp % 10;
c = temp / 10;
}
}
int p = 0;
for (int i = 39; i >= 0;i--)
if (ans[i] || p)
{
printf("%d", ans[i]); p = 1;
}
printf("\n");
//system("pause");
return 0;
}
本文介绍了一种使用C语言实现的大数阶乘计算方法。通过手动管理数组来存储和计算大于标准数据类型所能表示的数值范围的结果。这种方法适用于计算如30!这样的大数阶乘。
884

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



