c语言计算大数阶乘

发布时间:2024-11-23 20:39

计算机二级C语言:理解数据结构,多刷编程题目 #生活技巧# #工作学习技巧# #技能证书备考#

最新推荐文章于 2024-09-28 17:01:49 发布

l455702707 于 2019-02-19 17:57:30 发布

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

问题描述

  输入一个正整数n,输出n!的值。
  其中n!=1*2*3*…*n。

算法描述

  n!可能很大,而计算机能表示的整数范围有限,需要使用高精度计算的方法。使用一个数组A来表示一个大整数a,A[0]表示a的个位,A[1]表示a的十位,依次类推。
  将a乘以一个整数k变为将数组A的每一个元素都乘以k,请注意处理相应的进位。

输入格式

  输入包含一个正整数n,n<=1000。

输出格式

  输出n!的准确值。

样例输入

10

样例输出

3628800

#include <stdio.h>

#define N 10000

int main()

{

int a[N]={1};

int k=0,l=1,n;

int i,j;

scanf("%d",&n);

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

{

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

{

a[j]=a[j]*i+k;

k=a[j]/10000;

a[j]=a[j]%10000;

}

if(k)

{

a[j]=k;

l++;

k=0;

}

}

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

for(i=l-2;i>=0;i--)

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

printf("\n");

return 0;

}

网址:c语言计算大数阶乘 https://www.yuejiaxmz.com/news/view/218777

相关内容

C语言学习错题集(一)
c语言printf输出格式
C语言学习
C语言个人财务管理示例
c语言原程序如下intx=496;printf('*%
语言C++之循环结构
剖析C语言中a=a+++++a的无聊问题
《C语言深度刨析》整理
网络用语与语言规范
用c语言实现旅行商问题的c

随便看看