这篇文章主要介绍C语言中如何使用递归解决青蛙跳台阶问题,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!
台阶的数量为n。
当 n = 1 时,青蛙有一种跳法,即跳1级台阶。
当 n = 2 时,青蛙有两种跳法,即跳两次1级台阶或跳一次2级台阶。
当 n = 3 时,青蛙可以先跳2级台阶再跳1级台阶,也可以选择先跳1级台阶再跳2级台阶,或者是跳三次1级台阶。依次类推,我们就能知道台阶数为n时青蛙的跳法。
但是,这样子是不是很麻烦呢,再仔细想一下。
还是当 n = 3 时,我们选择先跳1级台阶,剩下的2级台阶的跳法,是不是就是当 n = 2 时青蛙的跳法;我们选择先跳2级台阶,剩下的1级台阶的跳法,是不是就是当 n = 1 时青蛙的跳法。
由此可知,n = 3 时青蛙的跳法为 n = 1 时的跳法加上 n = 2 时的跳法。
当 n = N 时,N个台阶的跳法为 N-1 的跳法加上 N-2 的跳法。
乍一看,是不是感觉和斐波那契数列有点像,当然,还是有一丢丢不一样的,不过我们可以用同样的数学思想来解决这个问题。
#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
int flog(int n)
{
if (n == 1)
return 1;
else if (n == 2)
return 2;
else
return flog(n - 1) + flog(n - 2);
}
int main()
{
int n = 0;
int ways = 0;
printf("请输入台阶的数量:");
scanf("%d", &n);
ways = flog(n);
printf("青蛙有%d种跳法",ways);
return 0;
}
以上是“C语言中如何使用递归解决青蛙跳台阶问题”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注亿速云行业资讯频道!
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。