阶乘本身几乎如你所料。你推断a是。。。阶乘函数。b是实际参数。 = lambda a, b: b*a(a, b-1) if b > 0 else 1
此位是阶乘的应用: = (lambda a, b: a(a, b))(, b)
a是阶乘函数本身。它以自身为第一个论证,以评价点为第二个论证。只要你不介意a(a, b - 1)而不是a(b - 1),这可以概括为recursive_lambda:recursive_lambda = (lambda func: lambda *args: func(func, *args))
print(recursive_lambda(lambda self, x: x * self(self, x - 1) if x > 0 else 1)(6))
# Or, using the function verbatim:
print(recursive_lambda(lambda a, b: b*a(a, b-1) if b > 0 else 1)(6))
所以我们有外部部分:(lambda b: )(num)
如您所见,调用者必须通过的只是评估点。
如果您实际上想要一个递归lambda,您可以name the lambda:fact = lambda x: 1 if x == 0 else x * fact(x-1)
如果没有,您可以使用a simple helper function。您会注意到ret是一个可以引用自身的lambda,这与前面的代码中没有lambda可以引用自身不同。def recursive_lambda(func):
def ret(*args):
return func(ret, *args)
return ret
print(recursive_lambda(lambda factorial, x: x * factorial(x - 1) if x > 1 else 1)(6)) # 720
这两种方式你都不必用荒谬的方式把兰姆达传递给自己。