剑指offer系列之八:跳台阶问题

简介:

题目描述

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

这种问题的思路一般是采用数学归纳法,当n=1时,只有一种跳法;当n=2时,青蛙可以一次跳2级,也可以一次跳两级,需要跳两次,所以有两种跳法;当n=3的时候,首先考虑一次跳1级的情况,由于有3级,所以还有2级没跳,而跳两级的跳法已经在前面n=2的情况中计算得到了;下面考虑一次跳2级的情况,同样跳完2级的之后,还有1级没有跳,而跳剩下1级的方法是当n=1的时候计算得到的,所以可以归纳出当n=3的时候,跳法是f(3)=f(3-1)+f(3-2)。

为了确保正确性,我们继续分析当n=4的情况,由于青蛙第一次的跳法仍然只有两种。我们先分析第一次跳1级的情况,跳完1级之后,还有3级没有跳完,而剩下的3级的跳法总数可以由f(3)得到;当第一次跳2级的时候,还有2级没有跳完,所以剩余2级的跳法总数可以由f(2)得到。综合以上分析,我们得到当n=4的时候,跳法总数是f(4)=f(4-1)+f(4-2)=f(3)+f(2)。以此类推,我们可以得到台阶数为n的情况是f(n)=f(n-1)+f(n-2)。

这样,我们发现这仍然是一个斐波那契数列问题,基于上述分析,写出代码如下(已被牛客AC):

package com.rhwayfun.offer;

public class JumpStep {

    public int jumpFloor(int target) {
        int[] r = { 0, 1, 2 };
        if (target <= 2)
            return r[target];

        int one = 1;
        int two = 2;
        int result = 0;
        for (int i = 3; i <= target; i++) {
            result = one + two;
            one = two;
            two = result;
        }

        return result;
    }

    public static void main(String[] args) {
        int result = new JumpStep().JumpFloorII(3);
        System.out.println(result);
    }
}

跳台阶问题变种

题目描述

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

现在青蛙的能力升级了,不仅能一次跳1级,还能一次跳n级,这是了不起的进步(说笑的)。不管如何,我们仍然使用数学归纳法进行分析:

当n=1时,跳法只有1种,用f(1)=f(1-1)=1表示,下同;
当n=2时,可以一次跳1级,跳两次,也可以一次两2级,跳法有2种,f(2) = f(2-1) + f(2-2);//f(2-1)表示在有2级台阶的时候,第一次跳1级的跳法,其他类似
当n=3时,可以一次跳1级,跳3次,可以一次跳2级,下一次再跳1级,当然也可以一次跳3级,跳1次,所以跳法是f(3)=f(3-1)+f(3-2)+f(3-3)
……
当n=k的时候,f(k)=f(k-1)+f(k-2)+f(k-3)+…..+f(k-(k-1))+f(k-k)=f(0)+f(1)+f(2)+……+f(k-1),而f(k-1)=f((k-1)-1)+f((k-1)-2)+……+f((k-1)-(k-2))+f((k-1)-(k-1))=f(0)+f(1)+f(2)+……+f(k-2),
所以f(k)=2*f(k-1)。

得到上面的结论之后,我们写出如下代码(已被牛客AC):

public int JumpFloorII(int target) {
        if(target <= 0) return -1;
        if(target == 1) return 1;
        return 2 * JumpFloorII(target - 1);
    }
目录
相关文章
|
12月前
|
算法
代码随想录算法训练营第四十天 | LeetCode 343. 整数拆分、96. 不同的二叉搜索树
代码随想录算法训练营第四十天 | LeetCode 343. 整数拆分、96. 不同的二叉搜索树
56 1
|
12月前
|
算法
代码随想录算法训练营第二十九天 | 回溯算法总结
代码随想录算法训练营第二十九天 | 回溯算法总结
50 0
|
算法 Java 测试技术
LeetCode 周赛上分之旅 #46 经典二分答案与质因数分解
学习数据结构与算法的关键在于掌握问题背后的算法思维框架,你的思考越抽象,它能覆盖的问题域就越广,理解难度也更复杂。在这个专栏里,小彭与你分享每场 LeetCode 周赛的解题报告,一起体会上分之旅。
63 0
LeetCode 周赛上分之旅 #46 经典二分答案与质因数分解
|
算法 Android开发 容器
LeetCode 周赛上分之旅 #35 两题坐牢,菜鸡现出原形
学习数据结构与算法的关键在于掌握问题背后的算法思维框架,你的思考越抽象,它能覆盖的问题域就越广,理解难度也更复杂。在这个专栏里,小彭与你分享每场 LeetCode 周赛的解题报告,一起体会上分之旅。
91 0
|
算法 Android开发
LeetCode 周赛上分之旅 #34 按部就班地解决动态规划问题
学习数据结构与算法的关键在于掌握问题背后的算法思维框架,你的思考越抽象,它能覆盖的问题域就越广,理解难度也更复杂。在这个专栏里,小彭与你分享每场 LeetCode 周赛的解题报告,一起体会上分之旅。
71 0
|
存储 算法 C++
【每日算法Day 74】经典面试题:约瑟夫环,我敢打赌你一定不会最后一种方法!
【每日算法Day 74】经典面试题:约瑟夫环,我敢打赌你一定不会最后一种方法!
|
人工智能
|
算法 索引
从三道经典的leetcode题掌握二分法
前言 二分法是典型的搜索算法,其主要运用于有序序列中寻找目标值。其思路非常简单,就是不断比较搜索区间的中间值与目标值,当中间值等于目标值则结束搜索,如果中间值大于目标值,则继续搜索左半区间,反之搜索右半区间。 总结下,二分法就是在搜索过程中不断地将搜索区间减半,直到搜索到目标值或者搜索区间为空集。
三道好题分享
上课睡觉 - AcWing题库
84 0
|
人工智能 移动开发
【蓝桥杯集训·每日一题】AcWing 3805. 环形数组
文章目录 一、题目 1、原题链接 2、题目描述 二、解题报告 1、思路分析 2、时间复杂度 3、代码详解 三、知识风暴 线段树
102 0