Python系列 32 递归函数

递归函数

递归的特性

递归(recursion)是一种函数的调用方式,简而言之就是自己调用自己。

递归可以将一个大规模的问题分解成更小的相同问题,经过持续分解到最后问题规模小到可以用非常简单直接的方式来解决,或者将一个问题拆分成不同的各个部分,达到分而解决分而治之的目的。

一个递归函数必须要满足3要素:

  1. 必须有一个基本结束条件
  2. 必须能改变问题规模
  3. 必须调用自身

如下所示,这就是一个标准的递归函数:

def function(count):
    if count:
        print(count)
        function(count=count - 1)
    return

function(5)

# 5
# 4
# 3
# 2
# 1

回溯与递推

函数递归必然经历2个阶段,一个是回溯阶段,一个是递推阶段:

  • 回溯:函数不断递归调用自身时的阶段被称为回溯阶段
  • 递推:当函数退出递归调用时的阶段被称为递推阶段

下面是一个问姓名的问题,可以非常直白的阐述回溯和递推的2个概念。

首先,你问A多少岁,A会回答你他比B大10岁,然后你又问B多少岁,B会回答你它比C大10岁…

这样直至E,E说他的年龄是18岁,最后问A多少岁?

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值