跳台阶

跳台阶_牛客网

https://www.nowcoder.com/practice/8c82a5b80378478f9484d87d1c5f12a4?tpId=13&tqId=11161&rp=1&ru=/ta/coding-interviews&qru=/ta/coding-interviews/question-ranking

题目描述
一只青蛙一次可以跳上1级台阶,也可以跳上2级。求该青蛙跳上一个n级的台阶总共有多少种跳法(先后次序不同算不同的结果)。
多写几组数据可以发现这是一个斐波那契数列:

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

也可以根据排列组合公式计算,具体计算方法如下,需要import math

import math
class Solution:
    def jumpFloor(self, number):
        # write code here
        count = 0
        t = 1
        if number % 2 == 0:
            count += 1
            t = 2
        l = int(number/2)+1
        for i, j in zip(range(l,number+1),range(l-t,-1,-1)):
            count += math.factorial(i) / (math.factorial(j) * math.factorial(i-j))
        return int(count)
全部评论

相关推荐

牛客78099800...:实习现在还不捞26届的啊,我投了很多,没有进流程的,以为是在搞秋招,但意外发现大三的不少都面实习了
点赞 评论 收藏
分享
11-04 19:05
已编辑
东莞城市学院 单片机
不知道怎么取名字_:你这个要实习两年?哪有这么久的,感觉就是即使你毕业了,但还按实习的话,是不是不用给你缴社保公积金啥的
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务