实现一:
#include <stdio.h>
int main()
{
int n,s=0;
scanf("%d",&n);
for(int i=1;i<=n;i++)
{
int factorial=1;
for(int j=1;j<=i;j++)
factorial=factorial * j;
s=s+factorial;
}
printf("%d\n",s%1000000);
return 0;
}
实现一中运行输入100,输出-961703,明显溢出了,所以要采用实现二中的算法来实现,实际上25的阶乘有六个0,在25之后(包含25)的阶乘对结果无影响,所以当n>24时只需计算1!+2!+……+24!
实现二:
/*输入n,计算s=1!+2!+3!+……+n!的末六位(不含前导零)*/
#include <stdio.h>
/*从40开始答案就不便了,聪明的读者已经知道了,25!末尾有6个零,所以从第25项开始后面的项都不会影响和的末六位数字*/
int main()
{
const int MOD=1000000;
int n,s=0;
scanf("%d",&n);
if(n>24)
n=24;
for(int i=1;i<=n;i++)
{
int factorial=1;
for(int j=1;j<=i;j++)
factorial=(factorial * j % MOD);
s=(s+factorial)%MOD;
}
printf("%d\n",s);
return 0;
}原文:http://blog.csdn.net/persever/article/details/45567529