标题:求10000的阶乘
取消只看楼主
琛哥
Rank: 1
等 级:新手上路
帖 子:6
专家分:0
注 册:2010-5-18
结帖率:50%
已结贴  问题点数:20 回复次数:1 
求10000的阶乘
如何求10000的阶乘,我的代码总是超时
#include<stdio.h>
 __int64 a[10000]={0};
int main()
{
   __int64 n,i,j,k,c;
   while(scanf("%I64d",&n)!=EOF)
   {

    if(n==1) printf("1\n");
    else
    {
       __int64 *p;
        a[1]=1;k=1;
        p=&a[1];
        for(i=2;i<=n;i++)
        {   p=&a[1];
            for(j=1,c=0;j<=k;j++,p++)
            {*p=(*p)*i+c;
            c=(*p)/1000;
            *p=(*p)%1000;}
            while(c!=0)
            {
                a[k]=c%1000;
                c=c/1000;
                k++;
            }
        }
        p=&a[k];
        for(i=k;i>=1;i--,p--)
        printf("%I64d",*p);
        printf("\n");
    }
   }
}
搜索更多相关主题的帖子: 阶乘 
2010-05-23 15:48
琛哥
Rank: 1
等 级:新手上路
帖 子:6
专家分:0
注 册:2010-5-18
得分:0 
哦,我知道哪错了
2010-05-23 15:55



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-307838-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.326924 second(s), 8 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved