递归函数


在函数内部,可以调用其他函数。如果一个函数在内部调用本身,这个函数就是递归函数。

举个例子:计算阶乘n!=1*2*3*4*5*...*n,用函数fact(n)表示,可以看出

fact(n)=n!=f(n-1)*n

所以,fact(n)可以表示为n*fact(n-1),只有n=1时需要特殊处理。

于是,fact(n)用递归函数写出来就是:
def f(n):

if n==1:
         return 1

return f(n-1)*n

>>>f(3)

6

递归函数的特点是定义简单,逻辑清晰。理论上所有的递归函数都可以写成循环的方式,但循环的逻辑不如递归清晰。

使用递归函数要防止栈溢出。计算机中,函数调用是通过栈(stack)这种数据结构实现的。每当进入一个函数调用,栈就会增加一层栈帧,每当函数返回,栈就会减少一层栈帧。由于栈的大小不是无限的,所以递归调用次数过多就会出现栈溢出。

解决递归调用栈溢出的解决方法是通过尾递归优化。事实上,尾递归和循环的效果是一样的。所以,把循环看成一种特殊的尾递归也可以。

尾递归指的是:在函数返回的时候,调用自身本身,并且return语句不能包含表达式。

这样解释器或者编译器就可以把尾递归优化了。使递归调用多少次都只占一个栈帧,不会出现栈溢出的问题。

上面的fact(n)函数优化:
def fact(n):

return fact_iter(n,1)

def fact_iter(num,product):

if num ==1:
        return product

return fact_iter(num-1,num*product)

可以看到,return fact_iter(num-1,num*product)仅仅返回递归函数本身,num-1,num*product在函数调用前就会被计算,不影响函数调用。

fact(5)对应的fact_iter(5,1)的调用如下:

===> fact_iter(5, 1)
===> fact_iter(4, 5)
===> fact_iter(3, 20)
===> fact_iter(2, 60)
===> fact_iter(1, 120)
===> 120

尾递归调用时,如果做了优化,栈不会增长,无论调用多少次都不会导致栈溢出。

遗憾的是,大多数编程语言没有针对尾递归做优化,Python解释器也没有做优化,所以,即使把上面的fact(n)函数改成尾递归方式,也会导致栈溢出。

小结:

使用递归的优点是逻辑简单清晰,缺点是调用会导致栈溢出。

针对尾递归优化的语言可以通过尾递归防止栈溢出。尾递归事实上和循环一样,没有循环语句的语言智能通过尾递归实现循环。

Python标准的解释器没有针对尾递归优化,任何递归函数都存在栈溢出的可能。

转载于:https://blog.51cto.com/9130745/1730514

Python 2.4 递归函数相关推荐

  1. Python进阶之递归函数的用法及其示例

    作者 | 程序员adny 责编 | 徐威龙 封图| CSDN│下载于视觉中国 出品 |  AI科技大本营(ID:rgznai100) 本篇文章主要介绍了Python进阶之递归函数的用法及其示例,现在分 ...

  2. Python 进阶之递归函数一点都不难!

    封图| CSDN│下载于视觉中国 作者 | 程序员adny 责编 | 徐威龙 出品 |  AI科技大本营(ID:rgznai100) 本篇文章主要介绍了Python进阶之递归函数的用法及其示例,现在分 ...

  3. python递归函数详解-讲解Python中的递归函数

    在函数内部,可以调用其他函数.如果一个函数在内部调用自身本身,这个函数就是递归函数. 举个例子,我们来计算阶乘n! = 1 x 2 x 3 x ... x n,用函数fact(n)表示,可以看出: ? ...

  4. python中的递归函数是什么_Python中的递归函数

    递归函数recursion 函数直接或者间接调用自身,这就是递归函数.能用递归函数解决的问题,一般使用循环也可以解决.递归函数一定要有边界 递归函数的案例 一.斐波那契数列 求斐波那契数列前n项 de ...

  5. python中的递归函数是什么_Python中的递归函数是什么

    Python 递归函数 递归的特性: 1.调用自身函数 2.有一个结束条件 3.递归效率不高,可能会导致栈溢出(函数调用是通过栈这种数据结构实现的,每进入一个函数调用,栈就会增加一层栈帧,函数每返回, ...

  6. 【python基础】递归函数

    在函数内部,可以调用其他函数.如果一个函数在内部调用自身本身,这个函数就是递归函数 特性 必须有一个明确的结束条件 每次进入更深一层递归时,问题规模相比上次递归都应有所减少 相邻两次重复之间有紧密的联 ...

  7. Python写一个递归函数

    好的,下面是一个用 Python 实现递归函数的示例: deffactorial(n):if n == 1:return 1else:return n * factorial(n-1)print(fa ...

  8. python 递归函数 - 刘江的python教程_[PYTHON系列教程]→递归函数

    在函数内部,可以调用其他函数.如果一个函数在内部调用自身本身,这个函数就是递归函数.举个例子,我们来计算阶乘n! = 1 x 2 x 3 x ... x n,用函数fact(n)表示,可以看出:fa ...

  9. python学习day17 递归函数

    递归函数 http://www.cnblogs.com/Eva-J/articles/7205734.html def age(n):if n == 4:return 40elif n >0 a ...

最新文章

  1. topcoder srm 360 div1
  2. 从大数据技术参考模型角度梳理大数据标准
  3. FTP服务器管理【Linux运维之道之脚本案例】
  4. FPGA笔录(2)-触发器与锁存器原理
  5. python 自动点击上传以后上传文件,python使用selenium模拟点击网页实现自动导入上传文件功能...
  6. 算法积累之处理数组数据
  7. 智能会议系统(35)---深入浅出sip协议
  8. 图像的平滑与锐化代码matlab_【图像处理】轻松搞懂图像锐化
  9. bom更改编号 sap_【BOM精讲】BOM 入门基本常识
  10. Hibernate中的query.setFirstResult(),query.setMaxResults();
  11. BAT 解密:一张图概括互联网公司的标准技术架构
  12. CentOS7安装GNOME可视化界面
  13. 拓端tecdat|R语言中的多类别问题的绩效衡量:F1-score 和广义AUC
  14. 云计算机房的建设预算,云计算节省支出待验证 IDC机房建设每平米30万
  15. 运营进阶:打造好文案的万能公式
  16. 人生自我认识20条(经典转载)
  17. cnpm使用报错-最佳方案
  18. Android Studio 连接夜神模拟器的方法
  19. NetBeans 尚未部署该模块错误 解决方案
  20. 知乎 API v4 整理

热门文章

  1. Redis源码和java jdk源码中hashcode的不同实现
  2. linux中的apachectl是什么命令
  3. 何崚谈阿里巴巴前端性能优化最佳实践
  4. Sql server 2005带来的分页便利
  5. C++拾趣——有趣的操作符重载
  6. c/c++标准预定义宏
  7. OpenCV中的内存泄露问题(cvLoadImage,cvCloneImage)
  8. 【Dlib】dlib实现深度网络学习之 input层
  9. shell python优势_python的优势
  10. linux服务器之间调用反应慢,Linux使用ssh远程登录服务器反应慢的解决办法