栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Python

python基础学习-斐波那契数列实现

Python 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

python基础学习-斐波那契数列实现

介绍

首先介绍一下斐波那契数列,斐波那契数列(Fibonacci sequence),又称黄金分割数列,因数学家莱昂纳多·斐波那契(Leonardo Fibonacci)以兔子繁殖为例子而引入,故又称为“兔子数列”,指的是这样一个数列:0、1、1、2、3、5、8、13、21、34、……在数学上,斐波那契数列以如下被以递推的方法定义:F(0)=0,F(1)=1, F(n)=F(n - 1)+F(n - 2)
斐波那契数列指的是这样一个数列:

这个数列从第3项开始,每一项都等于前两项之和。

这里通过python用普通迭代的方法和递归的方法实现求斐波那契数列中的具体第几个数字。

普通迭代方法
print('迭代实现斐波那契数列')
def fab(n):
  n1 = 1
  n2 = 1
  n3 = 1

  if n < 1:
    print('输入有误')
    return -1

  while (n-2) > 0:
    n3 = n2 + n1
    n1 = n2
    n2 = n3
    n -= 1
  return n3

number = int(input('请输入寻找的第几个斐波那契数列对应数据:'))
result = fab(number)
if result != -1:
  print('第%d个斐波那契数列对应的数据为%d' % (number, result))

运行结果

递归方法
print('迭代实现斐波那契数列')
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)

number = int(input('请输入寻找的第几个斐波那契数列对应数据:'))
result = fab(number)
if result != -1:
  print('第%d个斐波那契数列对应的数据为%d' % (number, result))

运行结果

这里如果用递归的话,效率大大降低,耗时比较久

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/275074.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号