【C语言】青蛙跳台阶(两种青蛙跳)

简介: 【C语言】青蛙跳台阶(两种青蛙跳)

前言

🎈大家好,我是何小侠🎈

🌀大家可以叫我**小何或者小侠🌀**

🔴我是一名普通的博客写作者🔴

💐希望能通过写博客加深自己对于学习内容的理解💐

🌸也能帮助更多人理解和学习🌸

🍃我的主页:何小侠的主页🍃


这篇博客我们一起来学习青蛙跳台阶问题,也就是递归。希望大家能有所收获。

🍊

青蛙跳台阶(常见版本)🍊

规则:

有一只很厉害的青蛙一次可以跳上 1 级台阶,也可以跳上 2 级台阶。求该青蛙跳上一个 n 级的台阶总共有多少种跳法。

我们遇到这种问题还是需要找规律

很明显,我们能发现一些规律

我们假设 f ( n )就是跳上 n 级阶梯的方法,我们知道青蛙第一步只能跳1级或二级,

那么我们是不是可以推出 f ( n ) = f(n -1 )+ f (n -2)。

f ( n-1 )就是先跳1级后剩下n-1级的跳法,f ( n-2 )就是先跳2级后剩下n-2级的跳法.

或者说我们也可以得到

当我们的阶数为 n = 3 的时候,也就是 f( 3 ) = f (n - 1) + f (n - 2 ),这样是不是更清楚呢?

所以我们可以得到:

这就是我们最后得出的公式。其实就是一个变种的斐波那契数列

代码

#include<stdio.h>
int  f(int n)
{
  if (1 == n)
    return 1;
  else if (2 == n)
    return 2;
  else if (n > 2)
  {
    return f(n - 1) + f(n - 2);
  }
}
int main()
{
  int n = 0;
  printf("请输入你想累死青蛙的阶数\n");
  scanf("%d", &n);
  printf("青蛙要跳%d次\n",f(n));
  return 0;
}

青蛙跳台阶(另外版本)🍊

规则:

有一只青蛙,它是青蛙中战斗机,青蛙中的博尔特,它一次可以跳上一级台阶,也可以跳上二级台阶······也可以跳n级,求该青蛙跳上一个n级的台阶总共需要多少种跳法。

这个思路其实要和上面的一般版本青蛙跳结合一下。

我们看到它的第一步跳法如上所示,它既可以跳1级,也可以2级,也可以3级·····甚至直接跳到终点。

假设我们还是设f ( n ) 为 n 跳上n级台阶的跳法。 那么 f ( n ) = f (n -1) + f ( n -2 ) + ······f ( 2 ) + f ( 1 ) +f ( 0 ).

我们在上一个青蛙跳版本说过,如果青蛙一次只能跳1或2级,那么f ( n ) =f ( n -1)+ f (n-2 ),而在这个版本不就是一个思路吗?青蛙的跳越的能力提升了,那么我们的等式也应该变长!

再来看看这个等式 f ( n ) = f (n -1) + f ( n -2 ) + ······f ( 2 ) + f ( 1 ) +f ( 0 ).
如果青蛙第一次跳1级那么剩下的级数就是n-1,
也就是说剩下f ( n-1)种跳法,
那么青蛙如果一次跳n-1级,
那么最后剩下的一级就是n阶级,也就是f (1),
最后f (0)就是我们的青蛙最厉害的时候,直接从地面跳到终点,
那么f (0)当然就==1了;

我们还是把我们的分析写成表格更好大家理解。

因为我们已经换了一直青蛙了,就那4 阶数举例吧。青蛙先跳1级剩下的就是f ( 3 )种跳法,先跳2级就是f ( 2 ),······最后就是直接从地面跳到终点就是 f ( 0 )就是 1种跳法。

最后我们要推出这个递归条件!

我们知道

f ( n ) = f (n -1) + f ( n -2 ) + ······f ( 2 ) + f ( 1 ) +f ( 0 ).

f (n -1 ) = f ( n -2 ) + ······f ( 2 ) + f ( 1 ) +f ( 0 ).

所以

f ( n = f( n -1 ) + f( n -1 ) = 2 * f (n -1).

代码🍊

#include<stdio.h>
int  f(int n)
{
  if (n < 3)
    return n;
  else if (n > 2)
  {
    return 2 * f(n - 1);
  }
}
int main()
{
  int n = 0;
  printf("请输入你想累死青蛙的阶数\n");
  scanf("%d", &n);
  printf("青蛙要跳%d次\n",f(n));
  return 0;
}

总结🍊

这篇博客我们介绍了斐波那契数列的变种两个青蛙跳问题,我们不仅能从中学到数学思维和表达,也能加强我们的递归理解和能力

最后如果这篇博客有帮助到你,欢迎点赞关注加收藏

如果本文有任何错误或者有疑点欢迎在评论区评论


目录
相关文章
|
8月前
|
存储 编译器 C语言
爱上C语言:函数递归,青蛙跳台阶图文详解
爱上C语言:函数递归,青蛙跳台阶图文详解
|
C语言
【C语言刷题】青蛙跳台阶
【C语言刷题】青蛙跳台阶
147 1
|
C语言
【C语言实现青蛙跳台阶问题】
【C语言实现青蛙跳台阶问题】
51 0
|
8月前
|
C语言
C语言递归问题【青蛙跳台阶】和【汉诺塔】
C语言递归问题【青蛙跳台阶】和【汉诺塔】
|
7月前
|
算法 C语言
C语言实现青蛙跳台阶问题
C语言实现青蛙跳台阶问题
71 5
|
8月前
|
C语言
【C语言】青蛙跳台阶 —— 详解
【C语言】青蛙跳台阶 —— 详解
|
8月前
|
C语言 索引
【C语言】C语言⻘蛙跳台阶问题--递归问题
【C语言】C语言⻘蛙跳台阶问题--递归问题
|
11天前
|
存储 算法 C语言
【C语言程序设计——函数】素数判定(头歌实践教学平台习题)【合集】
本内容介绍了编写一个判断素数的子函数的任务,涵盖循环控制与跳转语句、算术运算符(%)、以及素数的概念。任务要求在主函数中输入整数并输出是否为素数的信息。相关知识包括 `for` 和 `while` 循环、`break` 和 `continue` 语句、取余运算符 `%` 的使用及素数定义、分布规律和应用场景。编程要求根据提示补充代码,测试说明提供了输入输出示例,最后给出通关代码和测试结果。 任务核心:编写判断素数的子函数并在主函数中调用,涉及循环结构和条件判断。
50 23
|
11天前
|
算法 C语言
【C语言程序设计——函数】利用函数求解最大公约数和最小公倍数(头歌实践教学平台习题)【合集】
本文档介绍了如何编写两个子函数,分别求任意两个整数的最大公约数和最小公倍数。内容涵盖循环控制与跳转语句的使用、最大公约数的求法(包括辗转相除法和更相减损术),以及基于最大公约数求最小公倍数的方法。通过示例代码和测试说明,帮助读者理解和实现相关算法。最终提供了完整的通关代码及测试结果,确保编程任务的成功完成。
43 15
|
11天前
|
C语言
【C语言程序设计——函数】亲密数判定(头歌实践教学平台习题)【合集】
本文介绍了通过编程实现打印3000以内的全部亲密数的任务。主要内容包括: 1. **任务描述**:实现函数打印3000以内的全部亲密数。 2. **相关知识**: - 循环控制和跳转语句(for、while循环,break、continue语句)的使用。 - 亲密数的概念及历史背景。 - 判断亲密数的方法:计算数A的因子和存于B,再计算B的因子和存于sum,最后比较sum与A是否相等。 3. **编程要求**:根据提示在指定区域内补充代码。 4. **测试说明**:平台对代码进行测试,预期输出如220和284是一组亲密数。 5. **通关代码**:提供了完整的C语言代码实现
50 24

热门文章

最新文章