c语言1至40的阶乘

用一个包含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;
}