用一个包含50个元素的数组来进行大数存储的方法,计算阶乘,每一个数组元素存储一位数
仅供参考:
#include <stdio.h>
#include <stdlib.h>
int N;
int n,t=2,a=1,b=0;
int *s;
int main(int argc,char **argv) {//雨中飞燕之作
if (argc==1) {printf("Usage: %s number\nCalculate factorial of number(>=2)\n",argv[0]);return 1;}
N=atoi(argv[1]);
if (N<=1) N=10;
printf("%d!=\n",N);
n=N;
s=(int *)calloc(n,sizeof(int));
if (!s) return 2;
s[0]=1;s[1]=1;
for(;a<=*s||(++t<=n?(b=0,a=1):0);(*s==a++&&b)?(*s)++:0)
s[a]=(b+=s[a]*t)%10000,b/=10000;
for(printf("%d",s[*s]);--*s>0;) printf("%04d",s[*s]);
printf("\n");
free(s);
return 0;
}