码迷,mamicode.com
首页 > 编程语言 > 详细

Python 递归

时间:2018-06-23 22:46:48      阅读:205      评论:0      收藏:0      [点我收藏+]

标签:func   UNC   ret   溢出   设计   就是   直接   准备   递归算法   

一、特点

  递归算法是一种直接或者间接地调用自身算法的过程,再计算机编写程序中,递归算法对解决一大类问题是十分有效的。

  1、递归就是在过程或函数里调用自身。

  2、在使用递归策略时,必须有一个明确的递归结束条件,称为递归出口。

  3、递归算法解题通常显得很简洁,但递归算法解题的运行效率较低。所以一般不提倡用递归算法设计程序。

  4、在递归调用的过程中系统为每一层的返回点、局部量等开辟了栈来存储。递归次数过多容易造成栈溢出等。

二、要求

  1、每次调用在规模上都有所缩小(通常是减半);

  2、相邻两次重复直接有紧密的联系,前一次要为后一次做准备(通常前一次的输出就作为后一次的输入);

  3、在问题的规模极小时必须用直接给出解答而不再进行递归调用,因而每次递归调用都是有条件的,无条件的递归将造成死循环而不能正常结束。

三、实例

def calc(n):
print(n)
if n/2 >1:
res = calc(n/2)
print(‘res:‘,res)
print("N:",n)
return n
calc(10)

10
5.0
2.5
1.25
N: 1.25
res: 1.25
N: 2.5
res: 2.5
N: 5.0
res: 5.0
N: 10

四、斐波拉契数列
def func(arg1,arg2,stop):
if arg1 == 0:
print(arg1,arg2)
arg3 = arg1 + arg2
print(arg3)
if arg3 < stop:
func(arg2,arg3,stop)

func(0,1,30)

0 1
1
2
3
5
8
13
21
34

Python 递归

标签:func   UNC   ret   溢出   设计   就是   直接   准备   递归算法   

原文地址:https://www.cnblogs.com/Presley-lpc/p/9218812.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!