大数阶乘
时间限制:
3000 ms | 内存限制:
65535 KB
难度:
3
#include<cstring> #include<cstdio> #include<iostream> using namespace std; int num[200000]; int main() { int n; scanf("%d",&n); int h=0,p=0; memset(num,sizeof(num)); num[0]=1; for(int i=2;i<=n;i++) { h=0; int j; for(j=0;j<=p;j++) { num[j]=num[j]*i+h; h=num[j]/10; num[j]=num[j]%10; } while(h) { num[j]=h%10; h/=10; j++; } p=j; } for(int i=p-1;i>=0;i--)printf("%d",num[i]); printf("\n"); return 0; }