2019.10.16——跳台阶

题目描述

一只青蛙一次可以跳上1级台阶,也可以跳上2级。求该青蛙跳上一个n级的台阶总共有多少种跳法(先后次序不同算不同的结果)。

题目思路

这题主要考察的是递归的思路。
首先我们先思考,关于递归有两种设计方式,一是减而治之(每次让问题的规模减1),二是分而治之(每次让问题的规模减半,类似于归并排序)。
本题的话我们可以从题目得出,每次我们都是走一阶或者两阶台阶,那么显而易见这是一道减而治之思想的题目。那么我们要设计递归的方法。
如何编写一个递归函数?
1、这个递归函数的功能是什么,怎样调用这个函数,即设计好递归函数的返回值和参数列表;
2、什么时候应该结束这个递归,它的边界条件(出口)是什么 (边界条件);
3、在非边界情况时,怎样从第n层转变成第n+1层 (递推公式)。

我们只有清楚了上诉三个问题,才能写出一个正确的递归函数。
关于本题,我们可以知道,我们走的不是一阶就是两阶,那么举个例子,如果一共3阶台阶,(我们从顶往下)我们可以走一阶,也可以走两阶,走一阶剩二阶还有两种走法(一或者二),走两阶剩一阶只剩一种走法(一),合起来就是三种方法。我们根据这种思路,可以得出jumpFloor(n)=jumpFloor(n-1)+jumpFloor(n-2)这种递归形式。那么什么时候应该结束这个递归?当n=1时,返回1,n=2时,返回2。
根据上诉思路可以直接写出对应的代码。

代码

class Solution {
public:
    int jumpFloor(int number) {
      if(number<=0)  //number不符合输入
          return 0;
      if(number==1)
          return 1;
      if(number==2)
          return 2;
      return jumpFloor(number-1)+jumpFloor(number-2);
    }
};
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值