C语言-青蛙跳台阶算法最详细解释
2021/10/31 22:10:47
本文主要是介绍C语言-青蛙跳台阶算法最详细解释,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
所有的解释都写在下面的代码段里了。
#define _CRT_SECURE_NO_WARNINGS 1 #include <stdio.h> int fib(int n) { if (n <= 3) return n; else return fib(n - 1) + fib(n - 2); } int main() { //一只青蛙一次可以跳上1级台阶,也可以跳上2 级……它也可以跳上n 级。 //此时该青蛙跳上一个n级的台阶总共有多少种跳法? //分析青蛙的台阶跳法: //1个台阶:1种跳法:1 //2个台阶:2种跳法:1 1 / 2 //3个台阶:3种跳法:1 1 1 / 1 2 / 2 1 //4个台阶:5种跳法:1 1 1 1 / 1 1 2 / 1 2 1 / 2 1 1 / 2 2 //5个台阶:8中跳法:1 1 1 1 1 / 1 2 1 1 / 1 1 2 1 / 1 1 1 2 / 2 1 1 1/ 1 2 2 / 2 1 2 / 2 2 1 //... //不难发现,这其实就是一个斐波那契数列,从第三个项开始,后面每一项都等于前两项之和 int N; //台阶 int WAYS;//跳法 scanf("%d", &N); WAYS = fib(N); printf("%d个台阶,共有%d种跳法!", N, WAYS); return 0; }
运行结果:
这篇关于C语言-青蛙跳台阶算法最详细解释的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-05-15PingCAP 黄东旭参与 CCF 秀湖会议,共探开源教育未来
- 2024-05-13PingCAP 戴涛:构建面向未来的金融核心系统
- 2024-05-09flutter3.x_macos桌面os实战
- 2024-05-09Rust中的并发性:Sync 和 Send Traits
- 2024-05-08使用Ollama和OpenWebUI在CPU上玩转Meta Llama3-8B
- 2024-05-08完工标准(DoD)与验收条件(AC)究竟有什么不同?
- 2024-05-084万 star 的 NocoDB 在 sealos 上一键起,轻松把数据库编程智能表格
- 2024-05-08Mac 版Stable Diffusion WebUI的安装
- 2024-05-08解锁CodeGeeX智能问答中3项独有的隐藏技能
- 2024-05-08RAG算法优化+新增代码仓库支持,CodeGeeX的@repo功能效果提升