鱼C论坛

 找回密码
 立即注册
查看: 2915|回复: 0

[学习笔记] python 闭包

[复制链接]
发表于 2018-3-27 09:14:20 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
普通的程序员使用迭代,而天才程序员使用递归

递归必须满足以下两个条件:

1、必须调用函数本身

2、必须有停止的条件

斐波那契数列的迭代实现:

result1 = 0
result2 = 0
for i in range(1,21):
    if i == 1 or i == 2 :
        result1 = 1
        result2 = 1
        print('%d月总共有%d对兔子'%(i,result2))
    else:
        if i%2:
            result1  =  result1+result2
            print('%d月总共有%d对兔子' % (i, result1))
        else:
            result2 = result1+result2
            print('%d月总共有%d对兔子' % (i, result2))

斐波那契数列的递归实现:

def f(n):
    if n == 1 or n ==2:
        return 1
    else:
        return f(n-1)+f(n-2)

print(f(20))

递归函数中,进入递归的地方,其后面的代码都暂停,返回的时候继续执行后面的代码,
你进入了函数几次,最后就会return几次
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-5-14 18:17

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表