最强解析面试题:跳台阶 & 超级跳台阶「建议收藏!」

Posted 魏小言

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了最强解析面试题:跳台阶 & 超级跳台阶「建议收藏!」相关的知识,希望对你有一定的参考价值。


最强解析面试题:跳台阶 & 超级跳台阶「建议收藏!」

文章讲解 “ 跳台阶 & 超级跳台阶 ” 经典面试题,包含思路及源码,及解惑!

1、题目 - 跳台阶

一只青蛙一次可以跳上1级台阶,也可以跳上2级。求该青蛙跳上一个 n 级的台阶总共有多少种跳法(先后次序不同算不同的结果)。
数据范围:0 \\leq n \\leq 400≤n≤40
要求:时间复杂度:O(n)O(n) ,空间复杂度: O(1)O(1)

示例1

输入:
2
返回值:
2
说明:
青蛙要跳上两级台阶有两种跳法,分别是:先跳一级,再跳一级或者直接跳两级。因此答案为2

思路

记 n 级台阶,青蛙总有 f(n) 种跳法,则在完成台阶的最后一步有两种跳法:
1、青蛙跳一级,此时台阶总跳法为 f(n-1)
2、青蛙跳两级,此时台阶总跳法为 f(n-2)
故,综上 n 级台阶总的概率为 f(n-1) + f(n-2) ,即 f(n) = f(n-1) + f(n-2)。

注意:n == 0 , f(n) = 0;n == 1,f(n) = 1。

代码

package main

/**
 * 
 * @param number int整型 
 * @return int整型
*/
func jumpFloor( number int ) int {
    // write code here
    if number == 0{
        return 0
    }
    if number == 1{
        return 1
    }
    if number == 2{
        return 2
    }
  
    return jumpFloor(number-1)+jumpFloor(number-2)
}

2、题目 - 超级跳台阶

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

思路

记 n 级台阶,青蛙总有 f(n) 种跳法,则在完成台阶的最后一步有 N 种跳法:
1、青蛙跳一级,此时台阶总跳法为 f(n-1)
2、青蛙跳两级,此时台阶总跳法为 f(n-2)
3、青蛙跳两级,此时台阶总跳法为 f(n-3)

故,综上 n 级台阶总的概率为 f(n-1) + f(n-2) + f(n-3) + … + f(1),即 f(n) = 2*f(n-1), 。

代码

package main

/**
 * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
 * 
 * @param number int整型 
 * @return int整型
*/
func jumpFloorII( number int ) int {
    // write code here
    return 1<<(number-1)
}

Q&A

1、 不能使用 2^(n-1)

^ 在编程中属于位运算符,异或操作,故使用位运算 <<
2、相同的还有 “ 斐波那契数列 “、“ 矩形覆盖 “ 题目
见前后篇博文

附录

递归结构注意入口、出口、处理逻辑即可。

以上是关于最强解析面试题:跳台阶 & 超级跳台阶「建议收藏!」的主要内容,如果未能解决你的问题,请参考以下文章

LeetCode-面试题10.2-青蛙跳台阶问题

面试题10.2:青蛙变态跳台阶

力扣题解-面试题10- II. 青蛙跳台阶问题

力扣题解-面试题10- II. 青蛙跳台阶问题

面试题10- II. 青蛙跳台阶问题

面试题10- II. 青蛙跳台阶问题