在 Python 中查找数字 m 使其末尾有 n 个 0 的程序
假设我们有一个数字n。我们必须找到最小的数m,使得m的阶乘至少有n个0。
因此,如果输入类似于n=2,那么输出将是10,因为10!=3628800和9!=362880,带2个零的最小数字是10。
示例
让我们看看以下实现以获得更好的理解-
def count_fives(n):
cnt = 0
while n > 0:
n = n //5
cnt += n
return cnt
def solve(n):
left = 1
right = 5**24
while right - left > 5:
mid = int((right + left) / 10) * 5
fives = count_fives(mid)
if fives == n:
right = mid
left = right - 5
break
elif fives < n:
left = mid
else:
right = mid
return right
n = 2
print(solve(n))输入
2输出结果
10
热门推荐
10 圣诞祝福语简短小学
11 祖国七十华诞简短祝福语
12 老师送的祝福语简短
13 生日祝福语大全女生简短
14 祝女性生日祝福语简短
15 牛年女神节祝福语简短
16 情人表白祝福语简短大气
17 老公开业祝福语简短
18 官宣新年祝福语简短