Python编程实例02——实现斐波那契数列

系列目录

上一篇:Python编程实例01——打印九九乘法表



前言

关键词:斐波那契数列


实现斐波那契数列

1、代码分析

首先,我们先认识斐波那契数列的特点:第1项是0,第2项是1,从第3项开始每个数的值为其前两个数之和,即0,1,1,2,3,5,8…

通过观察,只有第1、2项没有规律,第3项开始都等于前两项之后,假设a代表前两项较小的第一项,b代表前两项中较大的一项,f(n)为第n项对应的值,那么:

  • 当n=0时,f(n)=0
  • 当n=1时,f(n)=1
  • 当n>1时,f(n)=f(n-1)+f(n-2),
    其中a=f(n-2),b=f(b-1)

2、代码实现

#定义函数
def fab(n):
    if n <= 0:
        return '传递的参数必须是大于0的正参数'
    elif n == 1:
        return 0
    else:
        #给前两个参数赋值
        a, b = 0, 1
        #初始化列表,列表前两个值已知为0和1
        fab_list = [0,1]
        #由于fb_list已经有两个数值,因此只需要循环n-2次即可
        for i in range(n-2):
            #实现后一个数等于前两个数之和
            a, b = b, a+b
            #结果加入列表
            fab_list.append(b)
        return fab_list

#打印,求斐波那契数列前11个数
print(fab(11))

输出结果

[0, 1, 1, 2, 3, 5, 8, 13, 21, 34, 55]

代码中,a,b = b,a+b语句实现了后一个数字等于前两个数字之和,即b=a+b。然后将“前两个数中的后一个”和“这个和”作为下次运算的前两个数,通过循环可以得到一组斐波那契数列。


总结

以上就是本节要讲的内容,本文先对斐波那契数列的特点进行数学分析,然后代码实现。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值