#include <stdio.h>
#include<iostream>
using namespace std;
int main()
{
int carry,n,j;
int a[40001];
int digit;
int temp,i;
while(scanf("%d",&n)!=EOF){
a[0]=1;digit=1;
for(i=2; i<=n; i++)
{
for(carry=0,j=1; j<=digit; ++j)
{
// cout<<a[j-1 ]<<" "<<i<<endl;
temp=a[j-1]*i+carry;
// cout<<"temp "<<temp<<endl;
a[j-1]=temp%10;
// cout<<"a[j-1] "<<a[j-1]<<endl;
carry=temp/10;
// cout<<"carry "<<carry<<endl;
}
while(carry)
{
//digit++;
a[++digit-1]=carry%10;
carry/=10;
}
}
for(int k=digit; k>=1; --k)
printf("%d",a[k-1]);
printf("\n");
//printf("length=%d\n",digit);
}
return 0;
}
大数阶乘
最新推荐文章于 2022-07-13 11:43:03 发布