青蛙跳台阶问题
Posted isshpan
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了青蛙跳台阶问题相关的知识,希望对你有一定的参考价值。
题目要求
一只青蛙一次可以跳上1级台阶,也可以跳上2级台阶。求该青蛙跳上一个 n 级的台阶总共有多少种跳法。
答案需要取模 1e9+7(1000000007),如计算初始结果为:1000000008,请返回 1。
算法分析
同样为斐波那契数列,注意初始值
补充说明:还有变种为可以跳n个台阶的,使用数组,或者有台阶坏的(美团一面),类似处理。
代码
class Solution(object):
def numWays(self, n):
if n == 0 or n == 1 or n == 2:
if n == 0:
return 1
else:
return n
x = 1
y = 2
res = 0
for i in range(3, n + 1):
res = x + y
x = y
y = res
return res % 1000000007
以上是关于青蛙跳台阶问题的主要内容,如果未能解决你的问题,请参考以下文章