C语言怎么求大数的阶乘?

#includeintmain(){inta[5000]={0,1},co=1,n;scanf("%d",&n);for(inti=2;i<=n;i++){intjinw... #include int main(){ int a[5000]={0,1},co=1,n; scanf("%d",&n); for(int i=2;i<=n;i++) { int jinwei=0; for(int j=1;j<=co;j++) { a[j]=a[j]*i+jinwei; if(a[j]/10000) { jinwei=a[j]/10000; a[j]%=10000; } else jinwei=0; } if(jinwei) a[++co]=jinwei; } printf("%d",a[co]); for(--co;co;--co) printf("%04d",a[co]); printf("\n"); return 0;} 展开
 我来答
无情天魔精致
推荐于2017-09-26 · TA获得超过1万个赞
知道大有可为答主
回答量:3711
采纳率:76%
帮助的人:1067万
展开全部

C语言利用数组计算超大整数的阶乘代码

#include <stdio.h>    

int main()    

{    

    int n;    

    int a[9000]; //确保保存最终运算结果的数组足够大    

     int digit = 1; //位数    

     int temp;   //阶乘的任一元素与临时结果的某位的乘积结果    

     int i, j, carry; //carry:进位    

     

     printf("please in put n:\n");    

    scanf("%d",&n);    

    a[0] = 1;   //将结果先初始化为1    

     

    for ( i=2; i<=n; i++ )  //开始阶乘,阶乘元素从2开始依次"登场"    

    {  //按最基本的乘法运算思想来考虑,将临时结果的每位与阶乘元素相乘    

         for( j=1, carry=0;  j<=digit; j++ )    

        {    

            temp = a[j-1] * i + carry; //相应阶乘中的一项与当前所得临时结果的某位相乘(加上进位)    

              a[j-1] = temp % 10; //更新临时结果的位上信息    

              carry = temp / 10; //看是否有进位    

         }    

        while(carry)    

        {    //如果有进位    

              a[++digit-1] = carry % 10; //新加一位,添加信息。位数增1    

            carry = carry / 10; //看还能不能进位    

         }    

    }    

    printf("n ! = ");    //显示结果    

    for(j = digit; j >=1;j--)    

    {    

        printf("%d",a[j-1]);    

    }    

    printf("\n");    

    return 0;    

}    




#include <stdio.h>    
int main()    
{    
    int n;    
    int a[9000]; //确保保存最终运算结果的数组足够大    
     int digit = 1; //位数    
     int temp;   //阶乘的任一元素与临时结果的某位的乘积结果    
     int i, j, carry; //carry:进位    
     
     printf("please in put n:\n");    
    scanf("%d",&n);    
    a[0] = 1;   //将结果先初始化为1    
     
    for ( i=2; i<=n; i++ )  //开始阶乘,阶乘元素从2开始依次"登场"    
    {  //按最基本的乘法运算思想来考虑,将临时结果的每位与阶乘元素相乘    
         for( j=1, carry=0;  j<=digit; j++ )    
        {    
            temp = a[j-1] * i + carry; //相应阶乘中的一项与当前所得临时结果的某位相乘(加上进位)    
              a[j-1] = temp % 10; //更新临时结果的位上信息    
              carry = temp / 10; //看是否有进位    
         }    
        while(carry)    
        {    //如果有进位    
              a[++digit-1] = carry % 10; //新加一位,添加信息。位数增1    
            carry = carry / 10; //看还能不能进位    
         }    
    }    
    printf("n ! = ");    //显示结果    
    for(j = digit; j >=1;j--)    
    {    
        printf("%d",a[j-1]);    
    }    
    printf("\n");    
    return 0;    
}
匿名用户
2013-09-26
展开全部
#include<stdio.h>
int f[4000];
void main()
{
int i,j,n;
scanf("%d",&n);
for(i=0;i<4000;i++)
f[i]=0;
f[0]=1;
for(i=2;i<=n;i++)
{
int c=0;//进位
for(j=0;j<4000;j++)
{
int s=f[j]*i+c;
f[j]=s%10;
c=s/10;
}
}
for(j=3999;j>=0;j--) if(f[j]) break;
for(i=j;i>=0;i--) printf("%d",f[i]);
printf("\n");
}
主要运用了,乘法的基本原理,用数组的每一个元素来存储个位十位百位千位……
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式