前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >面试题(1):青蛙跳台阶

面试题(1):青蛙跳台阶

作者头像
天道Vax的时间宝藏
发布2021-08-11 14:28:05
1730
发布2021-08-11 14:28:05
举报
文章被收录于专栏:用户5305560的专栏

题目:

一只青蛙一次可以跳上 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代码:

代码语言:javascript
复制
func JumpFloor(n int) int {
    a, b := 1, 1
    for ; n > 0; n-- {
        a, b = b, a + b
    }
    return a
}

Python代码:

代码语言:javascript
复制
def jump_floor(n):
    a, b = 1, 1
    for _ in range(n):
        a, b = b, a + b
    return a
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020/06/06 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 题目:
  • 思路:
  • 解法:
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档