递归函数使用

“”"
1、 一个球从100米高度自由落下,每次落地后反跳回原高度的一半;再落下,求它在第10次落地时,共经过多少米?(要求递归函数实现)
“”"

def work(n):
if n == 1:
return 100
else:
res = 100 / (2 ** (n - 2)) + work(n - 1)
return res

“”"
2、题目:猴子吃桃问题:
猴子第一天摘下若干个桃子,当即吃了一半,还不过瘾,又再吃了一个。第二天早上又将剩下的桃子吃掉一半,再吃了一个。
以后每天早上都吃了前一天剩下的一半 在加一个。
到第10天早上想再吃时,见只剩下一个桃子了。
请通过一段通过代码来计算第一天摘了多少个桃子?(递归实现)
“”"

def work1(n):
if n == 10:
return 1
else:
res = (work1(n + 1) + 1) * 2
return res

“”"
3、题目:小明买了一对刚出生的兔子,兔子从出生后第3个月开始,每个月都生一对兔子,
每对兔子出生后第三个月开始每个月都会生一对兔子,
假如兔子都不死,问100个月后小明的兔子为多少对?
(思路提示:重点在分析出兔子增长的规律,通过递归实现)
“”"

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值