码迷,mamicode.com
首页 > 其他好文 > 详细

上台阶

时间:2020-02-26 21:05:10      阅读:77      评论:0      收藏:0      [点我收藏+]

标签:测试   函数   main   多少   code   行数据   输入数据   开始   题目   

题目描述(动态规划)

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

上台阶

标签:测试   函数   main   多少   code   行数据   输入数据   开始   题目   

原文地址:https://www.cnblogs.com/wisteria68/p/12368751.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!