爬楼梯,可以每次走1级或者2级,输入楼梯的级数,求不同的走法数 c++代码提示
时间: 2024-04-12 15:29:21 浏览: 121
c++用迭代法求解泰勒公式cosx和弦截法求方程的根.docx
5星 · 资源好评率100%
当楼梯的级数为n时,不同的走法数等于前两级楼梯的走法数之和。
可以使用动态规划来解决这个问题,定义一个数组dp存储不同级数楼梯的走法数,初始状态dp[0]=1,dp[1]=1,然后从2开始迭代计算dp[i]=dp[i-1]+dp[i-2],最后返回dp[n]即为结果。
以下是C++代码示例:
```cpp
#include <iostream>
using namespace std;
int climbStairs(int n) {
if (n <= 1)
return 1;
int dp[n+1];
dp[0] = 1;
dp[1] = 1;
for (int i = 2; i <= n; i++) {
dp[i] = dp[i-1] + dp[i-2];
}
return dp[n];
}
int main() {
int n;
cout << "请输入楼梯的级数:";
cin >> n;
cout << "不同的走法数为:" << climbStairs(n) << endl;
return 0;
}
```
你可以将以上代码复制到C++编译器中运行,输入楼梯的级数即可得到不同的走法数。
阅读全文