C语言小明爬楼梯,如果每次可以上一个台阶或者两个台阶或者3个台阶,那么上 n 级台阶一共有多少种方案?
时间: 2024-02-11 13:09:32 浏览: 148
可以使用递归的方式求解小明爬楼梯问题,代码如下:
```c
#include <stdio.h>
int climbStairs(int n) {
if (n == 1) {
return 1;
} else if (n == 2) {
return 2;
} else if (n == 3) {
return 4;
} else {
return climbStairs(n-1) + climbStairs(n-2) + climbStairs(n-3);
}
}
int main() {
int n;
printf("请输入台阶数 n:");
scanf("%d", &n);
printf("上 %d 级台阶的方案数为:%d\n", n, climbStairs(n));
return 0;
}
```
在这个程序中,我们定义了一个函数 `climbStairs`,用来递归计算上 n 级台阶的方案数。如果 n 小于等于 3,则直接返回对应的方案数,否则,递归计算上 n-1 级、n-2 级和 n-3 级台阶的方案数之和。最终得到上 n 级台阶的方案数。
相关问题
小明爬楼梯,如果每次可以上一个台阶或者两个台阶或者3个台阶,那么上 n 级台阶一共有多少种方案?(C语言实现)
好的,这里给出使用 C 语言实现的代码:
```c
#include <stdio.h>
int climbStairs(int n) {
if (n == 1) {
return 1;
}
if (n == 2) {
return 2;
}
if (n == 3) {
return 4;
}
int dp[n+1];
dp[1] = 1;
dp[2] = 2;
dp[3] = 4;
for (int i = 4; i <= n; i++) {
dp[i] = dp[i-1] + dp[i-2] + dp[i-3];
}
return dp[n];
}
int main() {
int n = 4;
int res = climbStairs(n);
printf("n = %d, res = %d\n", n, res); // 输出:n = 4, res = 7
return 0;
}
```
当输入 n=4 时,输出为 7。
小明一次可以走1到3个台阶,c语言递归求n个台阶多少种走法
在C语言中,我们可以使用递归来解决这个问题,这是一个典型的动态规划问题,可以用斐波那契数列的思想来理解。小明每次上楼可以选择1步、2步或3步,所以他走到第n个台阶的不同走法可以通过前面几步走法组合而来。当n等于1或者2时,只有1种走法;当n大于2时,就等于前一步(n-1)的走法加上前两步(n-2)的走法加上前三步(n-3)的走法。
下面是C语言的递归函数示例:
```c
#include <stdio.h>
int climbStairs(int n) {
// 基线条件:如果只有1个台阶,有1种走法
if (n == 1 || n == 2)
return n;
// 递归条件:第n个台阶的走法 = 第(n-1)个 + 第(n-2)个 + 第(n-3)个
else
return climbStairs(n - 1) + climbStairs(n - 2) + climbStairs(n - 3);
}
int main() {
int steps = 8; // 想要计算8个台阶有多少种走法
printf("The number of ways to climb %d stairs is: %d\n", steps, climbStairs(steps));
return 0;
}
```
当你运行这个程序,输入不同的台阶数,它会打印出对应的走法总数。
阅读全文