走进递归经典——青蛙跳台阶问题详解

简介: 描述👏继汉诺塔问题之后,接下来就是青蛙跳台阶问题:​说一只青蛙一次可以跳上1级,也可以跳上2级,求该青蛙跳上一个n级的台阶总共有多少种跳法。刚开始感觉像是在算阶乘,考虑先后次序不同算不同的结果嘛;看完才发现我格局低咯,这题其实蛮有意思。

image.png

分析👏

不同的结果嘛;细想就发现我格局低了,这题其实很有意思。


那么我们先分析一下,我青蛙只能跳1或2级,一级台阶只有一种;跳二级时,可跳两次一级或跳一次二级;跳3级时,跳一个二级和一个一级,即二级台阶跳法+一级台阶跳法;跳四级时,先跳一级后,剩三级台阶;或先跳两级,剩二级台阶,可能性就是三级台阶跳法+二级台阶跳法……


规律出来后其实不难发现和我们之前研究的斐波那契似乎有些渊源,但又有不同,我暂且称它为特殊斐波那契数列,稍作对比:

斐波那契:

image.png

image.png

实现👏

知道原理和模型就不难理解问题的本质,接下来就是衔接与打磨。这里我们先自义定一个 Frog函数来模拟情景:

#include<stdio.h>
  int Frog(int n)
  {
    if (n == 1)
    {
      return 1;
    }
    if (n == 2)
    {
      return 2;
    }
    return Frog(n - 1) + Frog(n - 2);//大于2级台阶就进入递归部分
  }
  int main()
  {
    int n = 0;
    printf("please input the number of steps:");
    scanf("%d", &n);
    int num = Frog(n);//传参开始计算
    printf("%d\n", num);
    return 0;
  }

执行结果如下图所示:(假设为6级台阶)

image.png

格局打开👏

以上只是针对的是初始步数对应为n =1或n=2时,我们继续深入思考一下,n更大时,n=3,4,5,……,m 时又该怎么办呢?当n = n 时,共有n种跳的方式,第一次跳出一阶后,后面还有Fib(n-1)中跳法; 第一次跳出二阶后,后面还有Fib(n-2)中跳法…第一次跳出n阶后, 后面还有 Fib(n-n)中跳法.这时候我们可以把函数部分再补充一下如下:

#include<stdio.h>
    int Frog(int n,int m)
    {
        if (n == 1)
        {
            return 1;
        }
        if (n == 2)
        {
            return 2;
        }
        if (n == 3)
        {
            return 4;
        }
    ……
    ……
        if(n==m)
        {
        return ?;  //(跳m级台阶方案)
        }
    Frog(n-1)+Frog(n-2)+Frog(n-3)+……+Frog(n-m);
    }


相关文章
|
8月前
|
存储 缓存 算法
【数据结构与算法】【小白也能学的数据结构与算法】递归 分治 迭代 动态规划 无从下手?一文通!!!
【数据结构与算法】【小白也能学的数据结构与算法】递归 分治 迭代 动态规划 无从下手?一文通!!!
|
7月前
|
C语言
|
8月前
|
算法 索引
【力扣经典面试题】55. 跳跃游戏
【力扣经典面试题】55. 跳跃游戏
|
8月前
|
算法 测试技术 索引
【力扣经典面试题】45. 跳跃游戏 II
【力扣经典面试题】45. 跳跃游戏 II
|
存储 算法 C语言
深度理解递归,手撕经典递归问题(汉诺塔,青蛙跳台阶),保姆级教学。
深度理解递归,手撕经典递归问题(汉诺塔,青蛙跳台阶),保姆级教学。
【经典笔试题2】
首先分析代码,a是数组名,是数组首元素地址,&a取到整个数组的地址,+1跳过了整个数组,a强转成int*类型,然后赋值给ptr,此时ptr指向的就是数组a后面的地址,如下图:
|
存储 算法 C++
【每日算法Day 74】经典面试题:约瑟夫环,我敢打赌你一定不会最后一种方法!
【每日算法Day 74】经典面试题:约瑟夫环,我敢打赌你一定不会最后一种方法!
|
算法 索引
从三道经典的leetcode题掌握二分法
前言 二分法是典型的搜索算法,其主要运用于有序序列中寻找目标值。其思路非常简单,就是不断比较搜索区间的中间值与目标值,当中间值等于目标值则结束搜索,如果中间值大于目标值,则继续搜索左半区间,反之搜索右半区间。 总结下,二分法就是在搜索过程中不断地将搜索区间减半,直到搜索到目标值或者搜索区间为空集。
|
算法 Java 测试技术
大厂面试题:求根号2简单?高级算法你肯定不会
大厂面试题:求根号2简单?高级算法你肯定不会
244 0
大厂面试题:求根号2简单?高级算法你肯定不会
|
机器学习/深度学习 C++
【力扣·每日一题】1036. 逃离大迷宫 (C++ bfs 思维)
【力扣·每日一题】1036. 逃离大迷宫 (C++ bfs 思维)
100 0
【力扣·每日一题】1036. 逃离大迷宫 (C++ bfs 思维)