Python代码使用递归算法、迭代算法分别实现斐波那契数列的计算
递归算法的代码实现:
print('斐波那契数列的计算\n')
def fab(n):
if n < 1:
print('输入有误!')
return -1
if n == 1 or n ==2:
return 1
else:
return fab(n-1)+fab(n-2)
result = fab(20)
if result != -1:
print('总共有%d对兔子出生!' % result)
迭代算法的代码实现:
#迭代完成斐波那契数列计算,计算次数多的情况下,迭代计算速度比递归要快
def fab(n):
n1 = 1
n2 = 1
n3 = 1 #给 n3 赋一个初值
if n < 1:
print('输入有误!')
return -1
while (n-2) > 0: #当n为3时,大于0,n3=n2+n1
n3 = n2 + n1
n1 = n2 #计算下一次迭代,将n1与n2依次后移,n2给现在的n1,之前的n3给n2,重复运算求和
n2 = n3
n -=1 #计算一次减少一次n,直到n为2时,跳出循环
return n3
result = fab(20)
if result != -1:
print('总共有%d对兔子!'% result)