首页 > 编程语言 > 详细

python之理解——递归

时间:2018-07-25 00:37:17      阅读:226      评论:0      收藏:0      [点我收藏+]

古之欲明明德于天下者,先治其国;欲治其国者,先齐其家;欲齐其家者,先修其身;欲修其身者,先正其心;欲正其心者,先诚其意;欲诚其意者,先致其知,致知在格物。物格而后知至,知至而后意诚,意诚而后心正,心正而后身修,身修而后家齐,家齐而后国治,国治而后天下平。

这是从林海峰博客里面copy的。很好的解释了,python函数的递归。

那什么是递归?

在函数内部,可以调用其他函数。如果在调用一个函数的过程中直接或间接调用自身本身

技术分享图片
def digui(n):
    print(n)
    digui(n)
digui(10)
递归的样子

这个函数是无休止进行下去的,如何停止?

所以我们需要利用函数的返回值——return

简单举例递归

技术分享图片
def fan(n):
    # print(n)
    if int(n / 2) == 0:
        return n
    res=fan(int(n / 2))
    return res
v=fan(5)
print(v)
初识递归
1.fan(5)——调用函数fan,n=5
2. print(n)——打印5,表示n=5
3.if int(n / 2) == 0:——判断5/2是否为0,不满足
4. res=fan(int(n / 2))——执行res,fan(2)*取整*
5.fan(2)——执行fan(2)
6.print(2)——打印2,表示n=2
7.if int(n / 2) == 0:——判断2/2是否为0,不满足
8.res=fan(int(n / 2))——执行res,fan(1)
9.fan(1)——执行fan(1)
10.print(1)——打印1,表示n=1
11.if int(n / 2) == 0:——判断1/2是否为0,*取整*,满足
12.return n——返回n,n现在等于1
13.思考:n等于1返回的历程
是直接返回到fan(5)?还是先返回到fan(2),fan(2)得到一个返回值,fan(2)再返回到fan(5)

用更简单的例子来说就是:

假如我是一个班级的学生,我想在我的班找一本书。

我问同学A:“同学你知道书在什么地方?”

A回答:“我不知道,我帮你问问B”

A问B:“同学你知道书在什么地方?”

B回答A:“我不知道,我帮你问问C”

B问C:”同学你知道书在什么地方?”

C回答B:“书在书架的最下面”

B现在知道书在什么地方,B就告诉A,然后A就告诉我。

技术分享图片
students_list=[A,B,C,D]
def fund_book(students_list):
    if len(students_list)==0:
        return 没有人知道书在什么地方
    student=students_list.pop(0)
    if student==C:
        return{0}说:我知道,书放在书架最下面.format(student)

    print(同学{0},你知道书在哪里?.format(student))
    print({0}回答道:我不知道,但念你慧眼识猪,你等着,我帮你问问{1}.format(student,students_list))

    res=fund_book(students_list)
    print(%s问的结果是: %res % (student, res))
    return res

v=fund_book(students_list)
print(v)
完美理解递归

总结

递归特性:

1. 必须有一个明确的结束条件

2. 每次进入更深一层递归时,问题规模相比上次递归都应有所减少

3. 递归效率不高,递归层次过多会导致栈溢出(在计算机中,函数调用是通过栈(stack)这种数据结构实现的,每当进入一个函数调用,栈就会加一层栈帧,每当函数返回,栈就会减一层栈帧。由于栈的大小不是无限的,所以,递归调用的次数过多,会导致栈溢出)

 

python之理解——递归

原文:https://www.cnblogs.com/shi-py-rengongzhineng/p/9363412.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!