• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

Python全栈之路系列之递归

python 搞代码 4年前 (2022-01-09) 19次浏览 已收录 0个评论

所谓递归其实就是函数本身调用函数,直到满足指定条件之后一层层退出函数, 例如

从前有座山,山里有座庙,庙里有个老和尚,正在给小和尚讲故事呢!故事是什么呢?“从前有座山,山里有座庙,庙里有个老和尚,正在给小和尚讲故事呢!故事是什么呢?‘从前有座山,山里有座庙,庙里有个老和尚,正在给小和尚讲故事呢!故事是什么呢?……’”

  • 利用函数编写一个斐波那契数列

0, 1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144, 233,377,610,987,1597,2584,4181,6765,10946,17711,28657,46368

斐波那契数列就是前面给两个数相加得到后面一个数,依次往后

代码如下

#!/usr/bin/env python# _*_ coding: utf-8 _*_def Counter(n1, n2):    if n1 > 10000:  # 当要计算的值大于10000就退出        return    print("Counter:", n1)  # 输出当前计算到那个值了    n3 = n1 + n2  # 第一个值加上第一个值等于第三个值    Counter(n2, n3)  # 调用计数器函数,此时第一个值是调用函数传过来的最后一个值,而第二个值是计算出来的第三个值Counter(0, 1)  # 调用计数器函数

输出结果

/usr/bin/python3.5 /home/ansheng/Documents/PycharmProjects/blogcodes/斐波那契.pyCounter: 0Counter: 1Counter: 1Counter: 2Counter: 3Counter: 5Counter: 8Counter: 13Counter: 21Counter: 34Counter: 55Counter: 89Counter: 144Counter: 233Counter: 377Counter: 610Counter: 987Counter: 1597Counter: 2584Counter: 4181Counter: 6765Process finished with exit code 0
  • 利用递归获取斐波那契数列中的第10个数,并将该值返回给调用者

代码:

#!/usr/bin/env python# _*_ coding: utf-8 _*_def Counter(Index, Start, End):    print("第%d次计算,第一个数字是%d,第二个数字是%d" % (Index, Start, End))    if Index == 10:  # 如果要计算的值是10就退出        return Start    N = Start + End  # N等于第一个数加上第二个数    Number = Counter(Index + 1, End, N)  # 继续调用计数器函数,End相当与传给函数的第一个数,N是传给函数的第二个数    return Numberresult = Counter(1, 0, 1)print("得出的数字是:", result)

输出结果

/usr/bin/python3.5 /home/ansheng/Documents/PycharmProjects/blogcodes/递归.py第1次计算,第一个数字是0,第二个数字是1第2次计算,第一个数字是1,第二个数字是1第3次计算,第一个数字是1,第二个数字是2第4次计算,第一个数字是2,第二个数字是3第5次计算,第一个数字是3,第二个数字是5第6次计算,第一个数字是5,第二个数字是8第7次计算,第一个数字是8,第二个数字是13第8次计算,第一个数字是13,第二个数字是21第9次计算,第一个数字是21,第二个数字是34第10次计算,第一个数字是34,第二个数字是55得出的数字是: 34Process finished with exit code 0

原文链接

所谓递归其实就是函数本身调用函数,直到满足指定条件之后一层层退出函数, 例如

从前有座山,山里有座庙,庙里有个老和尚,正在给小和尚讲故事呢!故事是什么呢?“从前有座山,山里有座庙,庙里有个老和尚,正在给小和尚讲故事呢!故事是什么呢?‘从前有座山,山里有座庙,庙里有个老和尚,正在给小和尚讲故事呢!故事是什么呢?……’”

  • 利用函数编写一个斐波那契数列

0, 1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144, 233,377,610,987,1597,2584,4181,6765,10946,17711,28657,46368

斐波那契数列就是前面给两个数相加得到后面一个数,依次往后

代码如下

#!/usr/bin/env python# _*_ coding: utf-8 _*_def Counter(n1, n2):    if n1 > 10000:  # 当要计算的值大于10000就退出        return    print("Counter:", n1)  # 输出当前计算到那个值了    n3 = n1 + n2  # 第一个值加上第一个值等于第三个值    Counter(n2, n3)  # 调用计数器函数,此时第一个值是调用函数传过来的最后一个值,而第二个值是计算出来的第三个值Counter(0, 1)  # 调用计数器函数

输出结果

/usr/bin/python3.5 /home/ansheng/Documents/PycharmProjects/blogcodes/斐波那契.pyCounter: 0Counter: 1Counter: 1Counter: 2Counter: 3Counter: 5Counter: 8Counter: 13Counter: 21Counter: 34Counter: 55Counter: 89Counter: 144Counter: 233Counter: 377Counter: 610Counter: 987Counter: 1597Counter: 2584Counter: 418<span>本文来源gaodai#ma#com搞*!代#%^码网5</span>1Counter: 6765Process finished with exit code 0
  • 利用递归获取斐波那契数列中的第10个数,并将该值返回给调用者

代码:

#!/usr/bin/env python# _*_ coding: utf-8 _*_def Counter(Index, Start, End):    print("第%d次计算,第一个数字是%d,第二个数字是%d" % (Index, Start, End))    if Index == 10:  # 如果要计算的值是10就退出        return Start    N = Start + End  # N等于第一个数加上第二个数    Number = Counter(Index + 1, End, N)  # 继续调用计数器函数,End相当与传给函数的第一个数,N是传给函数的第二个数    return Numberresult = Counter(1, 0, 1)print("得出的数字是:", result)

输出结果

/usr/bin/python3.5 /home/ansheng/Documents/PycharmProjects/blogcodes/递归.py第1次计算,第一个数字是0,第二个数字是1第2次计算,第一个数字是1,第二个数字是1第3次计算,第一个数字是1,第二个数字是2第4次计算,第一个数字是2,第二个数字是3第5次计算,第一个数字是3,第二个数字是5第6次计算,第一个数字是5,第二个数字是8第7次计算,第一个数字是8,第二个数字是13第8次计算,第一个数字是13,第二个数字是21第9次计算,第一个数字是21,第二个数字是34第10次计算,第一个数字是34,第二个数字是55得出的数字是: 34Process finished with exit code 0

更多Python全栈之路系列之递归 相关文章请关注搞代码


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:Python全栈之路系列之递归

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址