递归实现 1:
#递归实现 def factorial(n): if n == 0: return 1 else: return n * factorial(n - 1)# 递归实现
递归实现 2:
#一行代码实现 def factorial(n): #如果n等于1或者等于0 将返回1否则返回n*factorial(n-1) return 1 if (n==1 or n==0) else n * factorial(n - 1)
迭代实现 3:
#阶乘的迭代实现 #在python3中reduce被放置在 functools 模块里 导入reduce #from functools import reduce def factorial(n): return 1 if (n==1 or n==0) else reduce(lambda y,x: x * y, range(1,n))