问题描述
我试图编写一个代码,打印出n的最后一个非零数字!(对于非负整数n) 我想我已经做了一切正确的事情。有人可以告诉我为什么我的代码不起作用吗?直到i = 15,一切似乎都是完美的。我的代码执行的操作是使用最后一个非零数字,然后将其乘以n,然后将结果除以10,直到没有5作为因子,最后输出最后一个数字。我也想达到的结果是为非常大的n(例如10e15甚至更大)打印正确的结果,但是我认为我的代码即使假设正确也无法执行此操作。任何提示将不胜感激。
代码如下:
int p(long long int n)
{
if (n != 1) {
long long int x = n * p(n - 1);
while (x % 10 == 0)
x /= 10;
return x % 10;
}
return 1;
}
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)