上台阶

Posted wisteria68

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了上台阶相关的知识,希望对你有一定的参考价值。

题目描述(动态规划)

有一楼梯共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)

以上是关于上台阶的主要内容,如果未能解决你的问题,请参考以下文章

递推-练习2--noi3525:上台阶

3525:上台阶

上台阶

[京东]上台阶

#1668 上台阶

上台阶