上台阶

题目描述(动态规划)

有一楼梯共m级,刚开始时你在第一级,若每次只能跨上一级或二级,要走上第m级,共有多少走法?
注:规定从一级到一级有0种走法。

输入

输入数据首先包含一个整数n(1<=n<=100),表示测试实例的个数,然后是n行数据,每行包含一个整数m,(1<=m<=40), 表示楼梯的级数。

输出

对于每个测试实例,请输出不同走法的数量。

样例输入

2
2
3

样例输出

1
2

破题思路

主要涉及函数:这就是一个斐波那契数列:登上第一级台阶有一种登法;登上两级台阶,有两种登法;登上三级台阶,有三种登法;登上四级台阶,有五种登法……
1,2,3,5,8,13......

程序源码

def fib(n):
    if n <= 3:
        return n-1
    p1, p2 = 1, 2
    for i in range(3, n):
        p1, p2 = p2, p1 + p2
    return p2

if __name__ == '__main__':
    n = int(input())
    for _ in range(n):
        m = int(input())
        print fib(m)
posted @ 2020-02-26 20:07  紫藤花下酒馆  阅读(211)  评论(0编辑  收藏  举报