递归练习

本文通过一个实例展示了如何使用递归遍历列表中的所有元素,例如列表l = ['jack',('tom', 23), 'rose',(14,55,67)]。同时,探讨了递归在解决爬楼梯问题的应用,计算当只能走1步或2步时,到达n阶楼梯顶部的不同走法数量。" 138787877,4907661,FunClip:开源AI视频剪辑与字幕工具,"['人工智能', '音视频', 'AI切片工具', '短视频', '自动化工具']
摘要由CSDN通过智能技术生成

“”"
用递归的方式输出 l = [‘jack’,(‘tom’, 23), ‘rose’,(14,55,67)]列表内的每一个元素
“”"

def dp(s):
    if isinstance(s, (int, str)):
        print(s, end=" ")
    else:
        for item in s:
            dp(item)


l = ['jack', ('tom', 23), 'rose', (14, 55, 67)]
dp(l)

执行结果:
在这里插入图片描述

爬楼梯算法:
n阶楼梯
每次只能走1步或者2步 有多少种方法可以走到楼顶

# 2阶
# 2 : 1 + 1   2

# 3阶
# 1+1+1
# 1+2
# 2+1
# 4阶
# 1+1+1+1
# 2+2
# 1+2+1
# 2+1+1
# 1+1+2

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


print(clim(4))

执行结果:
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值