程序一:
#include<stdio.h>
#include<time.h>
#include<conio.h>
int main()
{
int data[20000]={1,1,0}; //初始化,数组从1开始记数
int num; //阶乘大小
int digit=1; //每次阶乘得出结果的位数
time_t end;
time_t start;
scanf("%d",&num);
start=clock();
for(int i=1;i<=num;i++)
{
for(int n=1;n<=digit;n++)//先做每一位与i的乘积放在一个数组空间中
{
data[n]*=i;
}
for(int j=1;j<=digit;j++)//调整个元素的值,使之在0--9之间
{
if(data[j]>9)
{
for(int k=1;k<=digit;k++)
{
if(data[digit]>9) //位数增加
{
digit++;
}
data[k+1]+=data[k]/10;//调整
data[k]%=10;
}
}
}
}
end=clock();
printf("%.20lf\n",(double)(end-start)/CLK_TCK);
getch();
printf("%d!=",num);
for(int j=digit;j>0;j--)
{
printf("%d",data[j]);
}
printf("\n");
return 0;
}
程序二:
#include<stdio.h>
#include<time.h>
#include<conio.h>
int main()
{
int data[20000]={1,1,0}; //初始化,数组从1开始记数
int num; //阶乘大小
int digit=1; //每次阶乘得出结果的位数
time_t end;
time_t start;
scanf("%d",&num);
start=clock();
for(int i=1;i<=num;i++)
{
for(int n=1;n<=digit;n++)//先做每一位与i的乘积放在一个数组空间中
{
data[n]*=i;
}
for(int j=1;j<=digit;j++)//调整个元素的值,使之在0--9之间
{
if(data[j]>9)
{
for(int k=j;k<digit;k++)
{
data[k+1]+=data[k]/10; //调
data[k]%=10;
}
if(data[digit]>9) //位数增加
{
data[digit+1]+=data[digit]/10;
data[digit]%=10;
digit++;
}
}
}
}
end=clock();
printf("%.20lf\n",(double)(end-start)/CLK_TCK);
getch();
printf("%d!=",num);
for(int j=digit;j>0;j--)
{
printf("%d",data[j]);
}
printf("\n");
return 0;
}
程序一:
图片附件: 游客没有浏览图片的权限,请
登录 或
注册
程序二:
图片附件: 游客没有浏览图片的权限,请
登录 或
注册