Python函数之递归函数

什么是递归函数?

是指函数/过程/子程序在运行过程序中直接或间接调用自身而产生的重入现象。在计算机编程里,递归指的是一个过程:函数不断引用自身,直到引用的对象已知。

使用递归解决问题,思路清晰,代码少。但是在主流高级语言中(如C语言、Pascal语言等)使用递归算法要耗用更多的栈空间,所以在堆栈尺寸受限制时(如嵌入式系统或者内核态编程),应避免采用。所有的递归算法都可以改写成与之等价的非递归算法。

递归就是在函数内部调用自己的函数被称之为递归。

例:

#调用自己
def func():
    print('from func')
    func()
func()
#间接调用自己
def foo():
    print('from foo')
    bar()

def bar():
    print('from bar')
    foo()
foo()
#递归的实现:
def age(n):
    if n==1:
        return 18
    return age(n-1)+2
print(age(5))

递归的回溯与递推

1. 递推

像上边递归实现所拆解,递归每一次都是基于上一次进行下一次的执行,这叫递推。

2. 回溯

则是在遇到终止条件,则从最后往回返一级一级的把值返回来,这叫回溯。

例:

l =[1, 2, [3, [4, 5, 6, [7, 8, [9, 10, [11, 12, 13, [14, 15,[16,[17,18]],19]]]]]]]

def search(a):
  for item in a:
    if type(item) is list:
      search(item)
    else:
      print(item)

search(a)

小练习

阶乘:

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

输出结果:
Python
斐波那契数列:

def fib(n):
    if n<2:
        return n
    else:
        return fib(n-1)+fib(n-2)
print(fib(20))

输出结果:
Python
汉诺塔:

def hanoti(n,x1,x2,x3):
    if(n==1):
        print('move:',x1,'---',x3)
        return
    hanoti(n-1,x1,x3,x2)
    print('move:',x1,'---',x3)
    hanoti(n-1,x2,x1,x3)

使用递归函数向控制台打印3,2,1

def print_num(num):
    print(num)
    #出口
    if num==3:
        return
    num=num-1
    print_num(num)  #调用自己
    print('----->')

查找数字:通过程序查找输入的number值。

def search(number,start,end):
    if number ==start:
        return start
    else:
        middle=(start+end)//2
        if middle<=number:
            return  search(number,middle,end)
        else:
            return search(number,start,middle)
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值