3个回答
展开全部
#include<stdio.h>
void mul(int a[],int n)
{ int i,t=0;
for(i=1; i<=a[0]; i++)
{ a[i]=a[i]*n+t;
t=a[i]/10;
a[i]%=10;
}
while(t)
{ a[i++]=t%10;
t/=10;
}
a[0]=--i;
}
int main()
{ int a[40]= {1,1},i,n;
scanf("%d",&n);
printf("%d!=",n);
for(i=2; i<=n; i++)
mul(a,i);
for(i=a[0]; i>0; i--)
printf("%d",a[i]);
printf("\n");
return 0;
}
展开全部
真不简单,大数阶乘很难的。
1!=1
2!=2
3!=6
4!=24
5!=120
6!=720
7!=5040
8!=40320
9!=362880
10!=3628800
11!=39916800
12!=479001600
13!=6227020800
14!=87178291200
15!=1307674368000
16!=20922789888000
17!=355687428096000
18!=6402373705728000
19!=121645100408832000
20!=2432902008176640000
21!=51090942171709440000
22!=1124000727777607680000
23!=25852016738884976640000
24!=620448401733239439360000
25!=15511210043330985984000000
26!=403291461126605635584000000
前面的都是正确的,从27开始错了,可以看到最前面有一个0,其实0前面少了一个1。不过具体原因不明。
27!=0888869450418352160768000000
28!=34888344611713860501504000000
29!=011761993739701954543616000000
30!=352859812191058636308480000000
1!=1
2!=2
3!=6
4!=24
5!=120
6!=720
7!=5040
8!=40320
9!=362880
10!=3628800
11!=39916800
12!=479001600
13!=6227020800
14!=87178291200
15!=1307674368000
16!=20922789888000
17!=355687428096000
18!=6402373705728000
19!=121645100408832000
20!=2432902008176640000
21!=51090942171709440000
22!=1124000727777607680000
23!=25852016738884976640000
24!=620448401733239439360000
25!=15511210043330985984000000
26!=403291461126605635584000000
前面的都是正确的,从27开始错了,可以看到最前面有一个0,其实0前面少了一个1。不过具体原因不明。
27!=0888869450418352160768000000
28!=34888344611713860501504000000
29!=011761993739701954543616000000
30!=352859812191058636308480000000
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
#include<stdio.h>
int main(void)
{
double sum = 1;
for (int i = 1; i < 31; i++)
{
sum *= i;
}
printf("答案为:%lf\n", sum);
return 1;
}
int main(void)
{
double sum = 1;
for (int i = 1; i < 31; i++)
{
sum *= i;
}
printf("答案为:%lf\n", sum);
return 1;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询