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

简介: 描述👏继汉诺塔问题之后,接下来就是青蛙跳台阶问题:​说一只青蛙一次可以跳上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);
    }


相关文章
|
存储 算法 C语言
深度理解递归,手撕经典递归问题(汉诺塔,青蛙跳台阶),保姆级教学。
深度理解递归,手撕经典递归问题(汉诺塔,青蛙跳台阶),保姆级教学。
|
算法
【算法思维训练-剑指Offer联名 二】递归与循环篇
【算法思维训练-剑指Offer联名 二】递归与循环篇
90 0
汉诺塔+小青蛙跳台阶---《递归》
汉诺塔+小青蛙跳台阶---《递归》
101 0
|
算法 索引
从三道经典的leetcode题掌握二分法
前言 二分法是典型的搜索算法,其主要运用于有序序列中寻找目标值。其思路非常简单,就是不断比较搜索区间的中间值与目标值,当中间值等于目标值则结束搜索,如果中间值大于目标值,则继续搜索左半区间,反之搜索右半区间。 总结下,二分法就是在搜索过程中不断地将搜索区间减半,直到搜索到目标值或者搜索区间为空集。
快乐学算法or二分查找深度刨析
快乐学算法or二分查找深度刨析
|
算法 程序员
【算法集训 | 暑期刷题营】8.2题---暴力递归之深搜
【算法集训 | 暑期刷题营】8.2题---暴力递归之深搜
【算法集训 | 暑期刷题营】8.2题---暴力递归之深搜
两个经典的函数递归问题:青蛙跳台和贝诺塔
两个经典的函数递归问题:青蛙跳台和贝诺塔
130 0
两个经典的函数递归问题:青蛙跳台和贝诺塔
|
算法 前端开发
【算法之路】😉 吃透对称性递归 (一)
【算法之路】😉 吃透对称性递归 (一)
104 0
【算法之路】😉 吃透对称性递归 (一)
|
算法 前端开发
【算法之路】✌ 吃透对称性递归 (五)
【算法之路】✌ 吃透对称性递归 (五)
102 0
【算法之路】✌ 吃透对称性递归 (五)
|
算法 前端开发
【算法之路】😎 吃透对称性递归 (二)
【算法之路】😎 吃透对称性递归 (二)
109 0
【算法之路】😎 吃透对称性递归 (二)