题目描述:
一只青蛙一次可以跳上1级台阶,也可以跳上2级……它也可以跳上n级。求该青蛙跳上一个n级的台阶总共有多少种跳法。
思路:
当前台阶的跳法种数 = 当前台阶之前的所有台阶的跳法之和
意思就是
假设现在有n阶,可以跳完n阶的情况分别是:一次跳完F(0);先跳一步F(1),后面还有F(n-1)种跳法;或者先跳两步F(2),后面还有F(n-2)种跳法。依次类推,第一次跳出n阶后,后面还有 F(n-n)中跳法。可以得出:
F(n) = F(n-1)+F(n-2)+F(n-3)+..........+F(0)
class Solution:
def jumpfloorII(self,number):
if number <3:
return number
a = [0,1,2]
for i in range(3,number+1):
a.append(sum(a)+1)
return a[number]