您现在的位置是:群英 > 开发技术 > 编程语言
C语言中怎样求解青蛙跳台阶的问题?
Admin发表于 2021-12-27 19:00:481012 次浏览

    今天给大家分享一个比较经典的C语言示例,问题是一只青蛙一次可以跳1级或2级台阶,那么当台阶数为n时青蛙有多少种跳法?用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 的跳法。

    乍一看,是不是感觉和斐波那契数列有点像,当然,还是有一丢丢不一样的,不过我们可以用同样的数学思想来解决这个问题。

    二、代码实现

    1.参考代码

#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;
}

    2.运行结果

    总结

    以上就是关于C语言求解青蛙跳台阶问题的介绍,上述示例具有一定的借鉴价值,有需要的朋友可以参考学习,希望对大家学习C语言有帮助,想要了解更多可以继续浏览群英网络其他相关的文章。

文本转载自脚本之家

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。

相关信息推荐
2022-09-15 17:48:32 
摘要:本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于多线程的相关问题,包括了什么是程序、进程、线程、创建线程的三种方式、线程的状态等等内容,下面一起来看一下,希望对大家有帮助。
2022-02-08 20:10:10 
摘要:这篇文章我们来了解Java流程控制的相关内容,对新手学习和理解Java流程控制有一定的帮助,下文的介绍很详细,有需要的朋友可以参考,接下来就跟随小编来一起学习一下吧!
2022-09-28 17:57:19 
摘要:这篇文章主要给大家介绍了关于PHP中国际化字符串排序和比较对象的相关资料,这在日常开发中经常会用到,本文通过示例代码介绍的非常详细,需要的朋友可以参考下
云活动
推荐内容
热门关键词
热门信息
群英网络助力开启安全的云计算之旅
立即注册,领取新人大礼包
  • 联系我们
  • 24小时售后:4006784567
  • 24小时TEL :0668-2555666
  • 售前咨询TEL:400-678-4567

  • 官方微信

    官方微信
Copyright  ©  QY  Network  Company  Ltd. All  Rights  Reserved. 2003-2019  群英网络  版权所有   茂名市群英网络有限公司
增值电信经营许可证 : B1.B2-20140078   粤ICP备09006778号
免费拨打  400-678-4567
免费拨打  400-678-4567 免费拨打 400-678-4567 或 0668-2555555
微信公众号
返回顶部
返回顶部 返回顶部