c语言计算N的阶乘优化

#include<stdio.h>voidmain(){intN;printf("pleaseinputN");printf("\n");scanf("%d",&N);v... #include<stdio.h>
void main()
{
int N;

printf("please input N");
printf("\n");
scanf("%d",&N);

void jc(int x);
jc(N);

}

void jc(int x)
{
int i,j,k,p,m=1,n=1;
int a[99999]={1,1,0},b[99999]={0};
for(i=1;i<=x;i++)
{
for(j=2;j<=n;j++)
{
for(k=1;k<=m;k++)
{
a[k]=a[k]+b[k];
if(a[k]>=10)
{a[k]=a[k]-10;
a[k+1]=a[k+1]+1;

}
}if(a[m]+a[m]>=10)a[0]=m+1;
m=a[0];
}
n=n+1;
for(p=1;p<=m;p++)
b[p]=a[p];
}
for(i=a[0];i>=1;i--)
{
printf("%d",a[i]);
}
printf("\n");
printf("%d\n",a[0]);
}
程序没错 就是慢
展开
 我来答
百度网友fb002c2ca
2010-05-05 · 超过12用户采纳过TA的回答
知道答主
回答量:24
采纳率:0%
帮助的人:0
展开全部
高精度处理的时候可以用位压来加快速度
你的程序是数组每个元素存一位
实际上存4位是没有问题的
只要进位的时候判断是否>=10000
输出的时候加一些条件补齐零就行了
谢谢
kill31415
2010-05-05
知道答主
回答量:14
采纳率:0%
帮助的人:10.4万
展开全部
#include<stdio.h>
void main()
{
long N,i,s=1;
printf("please input N\n");
scanf("%d",&N);
if (N==0) printf("N!=1\n");
else {for (i=1;i<N+1;i++)
s*=i;
printf("N!=%d\n",s);
}
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式