【发布时间】:2021-12-31 12:26:54
【问题描述】:
需要创建一个函数来评估特定数字是否为阶乘。
为此,我构建了以下内容,并且正在运行
def is_factorial(n):
i = f = 1
while f < n:
i += 1
f *= i
return f == n
但是,现在我需要让它递归,但我正在努力解决它。
到目前为止,我已经设法做到以下几点
def isFactorial(m):
def factorial(x):
if x == 0:
return 1
else:
return x * factorial(x - 1)
if m == 1:
return True
elif m == 720:
return True
else:
factorialnumbers = []
感谢任何帮助。
编辑:很抱歉,但我忘记指定该函数应仅将一个整数作为输入。
【问题讨论】:
-
为什么要让它递归。它非常好,有些什么有效?如果你有大量的测试,你可以建立一个阶乘表,直到要测试的值的最大值。
-
除了将循环机械地转换为递归之外,没有像
factorial本身那样的“好的”递归版本。
标签: python python-3.x function recursion factorial