#include <stdio.h>
#include <stdlib.h>

#define N 10 //
N的阶乘


int main()
{       //
数组   1 1!
    int ary[N] = {1, 1};
    int i, j;

    for (i = 2; i <= N; i++)
    {
        //
各个下标的阶乘,第0位下标是位数,所以从第1位开始
        for (j = 1; j <= ary[0]; j++)
        {
            ary[j] = ary[j] * i;
        }

        //
处理进位问题 1W就进一位
        for (j = 1; j <= ary[0]; j++)
        {
            if (ary[j] >= 10000)
            {
                //
进位
                ary[j+1] = ary[j+1] + ary[j] / 10000; 
                //
进位后就只留下余数
                ary[j] = ary[j] % 10000;
            }
        }

        //
有进位的话,位数就+1
        //
这里j已经是位数大于1
        if (ary[j] >= 1)
        {
            ary[0]++;
        }
    }
    
    //
倒序输出
    for (j = ary[0]; j > 0; j--)
    {
        printf("%d", ary[j]);
    }
    printf("\r\n");
    return 0;
}

 

posted on 2010-01-18 14:17  o无尘o  阅读(1937)  评论(0编辑  收藏  举报