用python假设一段楼梯有15个台阶,小明一步最多能上3个台阶。编写程序计算小明上这段楼梯一共多少种方法。要求给出递推法和递归法两种代码。
时间: 2024-02-12 15:09:05 浏览: 142
好的,下面是代码实现:
#### 递推法
```python
# 定义一个列表,表示每个台阶的上法数
dp = [0] * 16
# 初始化前3个台阶的上法数
dp[0], dp[1], dp[2], dp[3] = 1, 1, 2, 4
# 使用递推公式计算每个台阶的上法数
for i in range(4, 16):
dp[i] = dp[i-1] + dp[i-2] + dp[i-3]
# 输出结果
print("小明上15个台阶的方法数为:", dp[15])
```
运行结果为:
```
小明上15个台阶的方法数为: 5768
```
解释一下代码:
首先,我们定义一个列表 `dp`,表示每个台阶的上法数,初始值都为0。这里我们需要计算16个台阶的上法数,因为要计算第15个台阶的上法数,需要用到前3个台阶的上法数。
然后,我们初始化前3个台阶的上法数,即 `dp[0]=dp[1]=1`,`dp[2]=2`,`dp[3]=4`,因为小明一步最多能上3个台阶,所以在前3个台阶上的上法数是确定的。
接下来,我们使用递推公式计算每个台阶的上法数,即 `dp[i]=dp[i-1]+dp[i-2]+dp[i-3]`。
最后,我们输出第15个台阶的上法数即可。
#### 递归法
```python
# 定义递归函数,计算从第i个台阶到第15个台阶的上法数
def countWays(i):
if i > 15: # 超过15个台阶,无法上楼
return 0
if i == 15: # 到达目标台阶,只有一种上法
return 1
return countWays(i+1) + countWays(i+2) + countWays(i+3)
# 输出结果
print("小明上15个台阶的方法数为:", countWays(0))
```
运行结果为:
```
小明上15个台阶的方法数为: 5768
```
解释一下代码:
首先,我们定义一个递归函数 `countWays(i)`,用于计算从第i个台阶到第15个台阶的上法数。
如果当前位置超过15个台阶,说明已经上到了终点,无法继续上楼,返回0。
如果当前位置到达了第15个台阶,说明已经到达目标位置,只有一种上法,返回1。
否则,当前位置可以往上1、2、3个台阶,分别计算这三种情况的上法数之和,即 `countWays(i+1) + countWays(i+2) + countWays(i+3)`。
最后,我们调用 `countWays(0)` 函数,计算从第0个台阶到第15个台阶的上法数,并输出结果。
希望能够帮到你!
阅读全文