【C语言】青蛙跳台阶问题

题目:一只青蛙一次可以跳上1级台阶,也可以跳上2级台阶。现求该青蛙跳上一个 n 级的台阶总共有多少种跳法。
题目分析:

  • n 等于 1 时,青蛙只能跳一级台阶到达,因此只有一种跳法,直接返回 1。
  • n 等于 2 时,青蛙可以选择跳一级或跳两级来到达,因此有两种跳法,直接返回 2。
  • 对于 n 大于 2 的情况,青蛙可以跳一级到第 n-1 级台阶,或者青蛙可以跳两级到第 n-2 级台阶,此时跳1级的跳法剩下1级台阶,跳2级的跳法剩下2级台阶,对于剩下1级台阶时,正好符合n == 1的情况,当剩下2级台阶时,正好符合n == 2的情况。
  • 因此,n > 2时,就是分别计算n-1与n-2的可能次数,相对应的就是跳1级台阶的跳法与跳2级台阶的跳法。为什么要进行n-1与n-2呢?因为跳1级台阶跳到n-1时,只剩1级台阶,程序就会走n == 1的情况,跳2级台阶跳到n-2时,只剩2级台阶,程序就会走n == 2的情况。
  • 最后将两种情况相加。
  • 看看代码吧:
cpp 复制代码
//青蛙跳台阶问题
//类似于斐波那契数
int frogJump(int n)
{
	//当台阶数为1时,只有1种跳法
	if (1 == n)
		return 1;
	//当台阶数为2时,只有2种跳法
	if (2 == n)
		return 2;
	//forgJump(n - 1)的作用为所有跳1层台阶的可能次数
	//forgJump(n - 2)的作用为所有跳2层台阶的可能次数
	//最后相加 == 总可能次数
	//n-1与n-2的意思为,从n直到剩下1层台阶,从n直到剩下2层台阶,然后就会进入n==1或n==2
	//进行返回
	return frogJump(n - 1) + frogJump(n - 2);
}
int main()
{
	int n = 0; //台阶数
	scanf("%d", &n);
	int count = frogJump(n);
	printf("跳法:%d\n", count);
	return 0;
}

如果您还理解不了,来看看代码图解吧:

这种递归方法虽然直观易懂,但是对于较大的n值,会导致大量的重复计算,效率较低。在实际应用中,我们通常会使用动态规划方法来避免这种重复计算,提高算法的效率。


相关推荐
女王大人万岁2 分钟前
Go标准库 io与os库详解
服务器·开发语言·后端·golang
露天赏雪6 分钟前
Java 高并发编程实战:从线程池到分布式锁,解决生产环境并发问题
java·开发语言·spring boot·分布式·后端·mysql
TracyCoder12316 分钟前
LeetCode Hot100(13/100)——238. 除了自身以外数组的乘积
算法·leetcode
CoderCodingNo17 分钟前
【GESP】C++五级练习题 luogu-P3353 在你窗外闪耀的星星
开发语言·c++·算法
Anastasiozzzz21 分钟前
LeetCode Hot100 215. 数组中的第K个最大元素
数据结构·算法·leetcode
定偶22 分钟前
mysql
c语言·数据库·mysql
让我上个超影吧22 分钟前
【力扣76】最小覆盖子串
算法·leetcode·职场和发展
NMIXX爻27 分钟前
线程控制 下
java·开发语言·jvm
Howrun77728 分钟前
C++ 类间交互
开发语言·c++
近津薪荼36 分钟前
优选算法——双指针5(单调性)
c++·学习·算法