#include
#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
{
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语言阶乘计算。n!=1*2*3*…*n
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答 默认 最新
- SZL-C 2017-01-16 13:52关注
#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<i;j++)// { a[j] = a[j] * i + k;//求阶乘的 //给出上限10000,如果在所得阶乘结果在范围内,那么值不变;否则,去掉最高位 k = a[j] / 10000; a[j] = a[j] % 10000; } if (k)//判断是否超出上限10000 { a[j] = k; l++; k = 0; } } printf("%d", a[l - 1]); //计算结果:如:输入10,则输出8800,其正确结果为:3628800 for (i = l - 2; i >= 0; i--)// printf("%04d", a[i]); printf("\n"); system("pause"); return 0; }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决评论 打赏 举报无用 2
悬赏问题
- ¥15 关于#python#的问题:求帮写python代码
- ¥20 MATLAB画图图形出现上下震荡的线条
- ¥15 LiBeAs的带隙等于0.997eV,计算阴离子的N和P
- ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘
- ¥15 来真人,不要ai!matlab有关常微分方程的问题求解决,
- ¥15 perl MISA分析p3_in脚本出错
- ¥15 k8s部署jupyterlab,jupyterlab保存不了文件
- ¥15 ubuntu虚拟机打包apk错误
- ¥199 rust编程架构设计的方案 有偿
- ¥15 回答4f系统的像差计算