关于递归函数举例

2018-12-29  本文已影响0人  _三余无梦生_

递归函数

在函数内部,可以调用其他函数。如果一个函数在内部调用自身本身,这个函数就是递归函数。
计算阶乘n! = 1 x 2 x 3 x ... x n

def fact(n):
    if n==1:
        return 1
    return n * fact(n - 1)

计算过程
===> fact(5)
===> 5 * fact(4)
===> 5 * (4 * fact(3))
===> 5 * (4 * (3 * fact(2)))
===> 5 * (4 * (3 * (2 * fact(1))))
===> 5 * (4 * (3 * (2 * 1)))
===> 5 * (4 * (3 * 2))
===> 5 * (4 * 6)
===> 5 * 24
===> 120

使用递归函数计算斐波那契数列第10位的数值是多少

大概思路:第10位的话就应该明白递归次数为10次,需要在外部每次减1 内部为1的时候返回(原想法是在想返回的值是否可以利用到数列的计算当中,不过想了半天我还是无法利用。所以只能用递归来进行计数了。)最后计算10次之后将值返回

 a ,b = 1,1
def fb(n):
    global a, b
    if n ==1:
        return n
    a ,b = b,a+b
    fb(n - 1)
    return a
print(fb(10))
#下面为常规for循环求数列
a,b = 1,1
for i in range(11):
    print(a,end=" ")
    a,b = b, a + b
输出结果
上一篇 下一篇

猜你喜欢

热点阅读