一只青蛙一次可以跳上1级台阶,也可以跳上2级……它也可以跳上n级。求该青蛙跳上一个m级的台阶总共有多少种跳法。
先列多项式:
f(n) = f(n-1) + f(n-2) + f(n-3) + … + f(n-m)
f(n-1) = f(n-2) + f(n-3) + … + f(n-m) + f(n-m-1)
化简得:f(n) = 2f(n-1) - f(n-m-1)
def jump(n,m):
if n>m:
return 2*jump(n-1,m)-jump(n-m-1,m)
else:
if n<=1:
return 1
else:
return 2*jump(n-1,n)
一只青蛙一次可以跳上1级台阶,也可以跳上2级……它也可以跳上n级。求该青蛙跳上一个n级的台阶总共有多少种跳法。
f(n) = f(n-1) + f(n-2) + f(n-3) + ... + f(n-(n-1)) + f(n-n)= f(0) + f(1) + f(2) + f(3) + ... + f(n-2)+f(n-1)
f(n-1) = f(0) + f(1)+f(2)+f(3) + ... + f((n-1)-1) = f(0) + f(1) + f(2) + f(3) + ... + f(n-2)
so f(n)=2*f(n-1)
def jump(n):
if n <= 1:
return 1
else:
return 2 * jump(n - 1)
一只青蛙一次可以跳上1级台阶,也可以跳上2级。求该青蛙跳上一个n级的台阶总共有多少种跳法(先后次序不同算不同的结果)。
如果n=1,只有一种跳法,那就是1
如果n=2,那么有两种跳法,2,[1,1]
如果n=3,那么有三种跳法,[1,1,1],[1,2],[2,1]
如果n=4,那么有五种跳法,[1,1,1,1],[1,1,2],[1,2,1],[2,1,1],[2,2]
如果n=5,那么有八种跳法,[1,1,1,1,1],[1,1,1,2],[1,1,2,1],[1,2,1,1],[2,1,1,1],[2,2,1],[2,1,2],[1,2,2]
结果为1,2,3,5,8 这就是斐波那切数列
#递归做法
def jump1(n):
if n==0:
return 0
elif n==1:
return 1
elif n==2:
return 2
else:
return jump1(n-1)+jump1(n-2)
#
print(jump1(5))
#非递归方法
def jump(n):
if n==0:
return 0
elif n==1:
return 1
elif n==2:
return 2
else:
n1=1
n2=2
count=2
while True:
count += 1
if count<=n:
tmp=n1
n1=n2
n2=tmp+n2
else:
break
return n2
print(jump(5))