输入数n;
将n!末尾的0去掉。再取最后9位。
把最后9位前面的0去掉;(把9位当做一个数,去掉无效的0)
输出得出的数;
n最大到10000000
比如输入38 输出 742912
楼上的代码思路没有问题,有点小bug,修改之后如下:
int foo(int n)
{
long r = 1;
int i;
for (i = 2; i <= n; i++)
{
r = r * i;
while (r % 10 == 0) r /= 10;
r = r % 1000000000;
}
return r;
}
int main()
{
printf("%d\n", foo(38));
}
n=38时,结果为742912
#include <stdio.h>
int foo(int n)
{
long r = 1;
for (int i = 2; i <= n; i++)
{
while (n % 10 == 0) n /= 10;
r = r * i % 100000000;
while (r % 10 == 0) r /= 10;
}
return r;
}
int main()
{
printf("%d", foo(38));
}
http://codepad.org/CSW9JWkG
956672
没有问题啊,10000000的时候,输出结果为574194688