可爱的小明特别喜欢爬楼梯,他有的时候一次爬一个台阶,有时候一次爬两个台阶,还有时候一次爬三个台阶 如果这个楼梯有20个台阶,小明一共有多少种爬法呢?代码
时间: 2024-04-29 08:23:47 浏览: 278
问题描述:有n级台阶,一个人每次上一级或者两级,问有多少种走完n级台阶的方法。
5星 · 资源好评率100%
这是一个典型的递归问题,可以采用递归算法解决。
代码如下:
```python
def climb_stairs(n):
if n == 1:
return 1
elif n == 2:
return 2
elif n == 3:
return 4
else:
return climb_stairs(n-1) + climb_stairs(n-2) + climb_stairs(n-3)
print(climb_stairs(20))
```
解释:
每次爬楼梯可以选择爬1、2或3个台阶,因此,要想知道爬完20个台阶的所有方法数,需要知道爬完19、18和17个台阶的方法数,而爬完19、18和17个台阶的方法数又可以通过递归求解。
这里需要注意的是,当n小于等于3时,需要特殊处理,因为只有1、2、3个台阶时的爬法是确定的。
阅读全文