Python 递归
2021-06-21 17:05
标签:name 自己 bmc nbsp number pytho http cto blog 递归的一个视觉效果呈现 - 捧着画框的蒙娜丽莎: 递归(Recursion),在数学与计算机科学中,是指在函数的定义中使用函数自身的方法。 在使用递归时,需要注意以下几点: 注意: 切勿忘记递归出口,避免函数无限调用。 相比递归,阶乘的迭代实现更容易理解: 现在,来使用递归来实现,和数学定义一样优雅。 当使用正整数调用 factorial() 时,会通过递减数字来递归地调用自己。 为了明确递归步骤,对 当数字减少到 1 时,递归结束。 从“编程之美”的角度来看,引用一句伟大的计算机编程名言: To iterate is human,to recurse divine. 优点: 缺点: Python 递归 标签:name 自己 bmc nbsp number pytho http cto blog 原文地址:https://www.cnblogs.com/zhang-zi-yi/p/9683109.html递归函数
迭代实现
>>> def factorial(n):
... result = 1
... for i in range(2, n+1):
... result *= i
... return result
...
>>>
>>> factorial(1)
1
>>>
>>> factorial(5)
120
>>>
>>> factorial(10)
3628800
递归实现
>>> def factorial(n):
... if n == 1:
... return 1
... else:
... return n * factorial(n - 1)
...
>>>
>>> factorial(1)
1
>>>
>>> factorial(5)
120
>>>
>>> factorial(10)
3628800
5!
进行过程分解:factorial(5) # 第 1 次调用使用 5
5 * factorial(4) # 第 2 次调用使用 4
5 * (4 * factorial(3)) # 第 3 次调用使用 3
5 * (4 * (3 * factorial(2))) # 第 4 次调用使用 2
5 * (4 * (3 * (2 * factorial(1)))) # 第 5 次调用使用 1
5 * (4 * (3 * (2 * 1))) # 从第 5 次调用返回
5 * (4 * (3 * 2)) # 从第 4 次调用返回
5 * (4 * 6) # 从第 3次调用返回
5 * 24 # 从第 2 次调用返回
120 # 从第 1 次调用返回
递归的优缺点:
迭代者为人,递归者为神。
– L. Peter Deutsch