python递归函数(10)

Posted shuopython

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了python递归函数(10)相关的知识,希望对你有一定的参考价值。

 

 

 

    一个函数在函数体内部调用自己,这样的函数称为递归函数,递归的次数在python是有限制的,默认递归次数是997次,超过997次会报错:RecursionError.

 

技术图片

 

一.递归函数案例

    案例一:计算数字N的阶乘(举个栗子:9的阶乘 = 9*8*7*6*5*4*3*2*1)

输出结果:

    可能对于案例一,你会觉得好像所谓的递归也没什么卵用的样子,我用for循环也能实现,那么我们继续往下看案例二或者案例三。

技术图片

 

    案例二:一球从100米高度自由落下,每次落地后反跳回原高度的一半;再落下,求它在第10次落地时,共经过多少米?第10次反弹多高?

输出结果:

    小窍门: 函数可以同时返回多个值,以元组的形式返回!!

技术图片

    案例三:猴子吃桃问题:猴子第一天摘下若干个桃子,当即吃了一半,还不瘾,又多吃了一个第二天早上又将剩下的桃子吃掉一半,又多吃了一个。以后每天早上都吃了前一天剩下的一半零一个。到第10天早上想再吃时,见只剩下一个桃子了。求第一天共摘了多少?

    计算结果:1534

技术图片

二.递归函数使用需要注意的问题

    1.一定要有结束条件

    2.默认递归次数是997次,超过997次会报错:RecursionError.

 

技术图片

 

猜你喜欢:

    1.python函数声明和调用

    2.python不定长参数*argc,**kargcs

    3.python return逻辑判断表达式

    4.python列表推导式

    5.python字典推导式

    6.python匿名函数

 

    转载请注明:猿说Python » python递归函数

 

技术交流、商务合作请直接联系博主
扫码或搜索:猿说python
技术图片
猿说python
微信公众号 扫一扫关注

以上是关于python递归函数(10)的主要内容,如果未能解决你的问题,请参考以下文章

python内置函数匿名函数递归

Python递归函数错误:“超出最大递归深度” [重复]

python函数递归-实例

python之内置函数匿名函数递归

python递归求斐波那契数列前10项

如何在自定义PyYAML构造函数中处理递归?