经典面试题:青蛙跳台阶

原创
2020/03/09 08:22
阅读数 124

「剑指Offer」里的经典题目,近期群里聊到这题,特来复习一波。

题目

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

思路

首先跳到 n 级台阶可以分解为两种情况:

1.之前跳到 n-1 级台阶,然后再跳 1 级到达 n 级;2.之前跳到 n-2 级台阶,然后再跳 2 级到达 n 级;

因此 n 级跳法数量,等于这两种情况之和。
即 F(n) = F(n-1) + F(n-2)

同理可继续推导:
F(n-1) = F(n-2) + F(n-3)
F(n-2) = F(n-3) + F(n-4)
...
F(2) = F(1) + F(0)
F(1) = 1
F(0) = 1

可见这是斐波那契数列,数列中从第三个数开始,每个数都是前两个数之和。那么只需从 F(0) + F(1) = F(2) 开始计算,一直加到 F(n) 即可得出结果。

Golang 解法

func JumpFloor(n int) int {    a, b := 1, 1    for ; n > 0; n-- {        a, b = b, a + b    }    return a}

Python 解法

def jump_floor(n):    a, b = 1, 1    for _ in range(n):        a, b = b, a + b    return a


其他解法还包括递归法, F(n) 不断拆解递归,也就是上面推导的前半部分,感兴趣可以自己尝试一下。



本文分享自微信公众号 - 面向人生编程(LifeOriented)。
如有侵权,请联系 support@oschina.cn 删除。
本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。

展开阅读全文
打赏
0
0 收藏
分享
加载中
更多评论
打赏
0 评论
0 收藏
0
分享
返回顶部
顶部