hhzlsf1214


私信TA

用户名:FOLIE

访问量:621

签 名:

等  级
排  名 4858
经  验 1561
参赛次数 0
文章发表 5
年  龄 0
在职情况 学生
学  校 学号 3192052051214
专  业 物联网19-1班 黄华梓

  自我简介:

解题思路:要进行高精度的计算,直接递推是不现实的,所以使用数组来储存这些位数

注意事项:用数组储存已有的阶乘数,在进行下一步的乘法操作,后得到的数分别按照位数储存进数组内,但由于数组先进后显示,所以得逆序输出

参考代码:

#include<stdio.h>

int main()

  int a[20001];//储存每一位所得到的数 

  int temp,digit,n,i,j=0;//temp每次的得数 digit每次得数的位数 

  scanf("%d",&n);

  a[0]=1; //从1开始乘 

  digit=1; //位数从第一位开始 

  for(i=2;i<=n;i++)

  {  

     int num=0;

     for(j=0;j<digit;j++)

     { 

       temp=a[j]*i+num;//将每一个数的位数都乘与i 

       a[j]=temp%10; //将一个数的每一数利用数组进行储存 

       num=temp/10;

}

while(num) //判断退出循环后num的值是否为0 

   a[digit]=num%10;//继续储存 

   num=num/10;

   digit++;

}

  }

  for(i=digit-1;i>=0;i--) //倒序输出每一位 

  printf("%d",a[i]);

  printf("\n");

  return 0;

}


 

0.0分

1 人评分

看不懂代码?想转换其他语言的代码? 或者想问其他问题? 试试问问AI编程助手,随时响应你的问题:

编程语言转换

万能编程问答

代码解释器

  评论区