题目描述 树老师爬楼梯,他可以每次走1级或者2级,输入楼梯的级数,求不同的走法数。 例如:楼梯一共有3级,他可以每次都走一级,或者第一次走一级,第二次走两级,也可以第一次走两级,第二次走一级,一共3种方法。但是如果第二层楼梯坏了,就只能先走到第一层,再走到第三层; 输入 第一行一个正整数M表示坏了的楼梯所在层; 第二行开始输入包含若干行,每行包含一个正整数N,代表楼梯级数,1≤M≤N≤30。 输出 不同的走法数,每一行输入对应一行输出。请用c++语言编码
时间: 2024-04-08 09:33:21 浏览: 90
以下是使用C++语言编写的解决方案:
```cpp
#include <iostream>
#include <vector>
using namespace std;
int climbStairs(int N, int M) {
vector<int> dp(N+1);
dp[0] = 1;
dp[1] = 1;
for (int i = 2; i <= N; i++) {
if (i == M) {
dp[i] = dp[i-1];
} else {
dp[i] = dp[i-1] + dp[i-2];
}
}
return dp[N];
}
int main() {
int M;
cin >> M;
vector<int> N_list;
int N;
while (cin >> N) {
N_list.push_back(N);
}
for (int N : N_list) {
int result = climbStairs(N, M);
cout << result << endl;
}
return 0;
}
```
在这个解决方案中,我们定义了一个`climbStairs`函数来计算给定楼梯级数和坏了的楼梯所在层的不同走法数。然后,在`main`函数中,我们根据输入的楼梯级数调用`climbStairs`函数并打印结果。
希望这个解决方案可以帮助到你!如果还有其他问题,请随时提问。
阅读全文