项目1:如何生成斐波那契数列-python实现

斐波那契(Fibonacci)数列是一个非常简单的递归数列,除第一个和第二个数外,任意一个数都可由前两个数相加得到。用计算机程序输出斐波那契數列的前 N 个数是一个非常简单的问题,许多初学者都可以轻易写出如下函数:

简单输出斐波那契數列前 N 个数

# -*- coding: utf-8 -*-

#python3.5

def fab(max):
    n, a, b = 0, 0, 1

    while n < max:
        print (b)

        a, b = b, a + b

        n = n + 1

执行 fab(5),我们可以得到如下输出:

fab(5)
1
1
2
3
5

上面代码简单但复用性差,使用 yield ,仅仅把 print b 改为了 yield b。

yield 的作用就是把一个函数变成一个 generator,带有 yield 的函数不再是一个普通函数,Python 解释器会将其视为一个 generator,调用 fab(5) 不会执行 fab 函数,而是返回一个 iterable 对象!在 for 循环执行时,每次循环都会执行 fab 函数内部的代码,执行到 yield b 时,fab 函数就返回一个迭代值,下次迭代时,代码从 yield b 的下一条语句继续执行,而函数的本地变量看起来和上次中断执行前是完全一样的,于是函数继续执行,直到再次遇到 yield

# -*- coding: utf-8 -*-

#python3.5

def fab(max):
    n, a, b = 0, 0, 1

    while n < max:
        yield b

        a, b = b, a + b

        n = n + 1

执行 fab(5),我们这样输出

for n in fab(5):
    print (n)
    
1
1
2
3
5

也可以这样输出:

f = fab(5)

f.next()
Traceback (most recent call last):

  File "<ipython-input-16-c3e65e5362fb>", line 1, in <module>
    f.next()

AttributeError: 'generator' object has no attribute 'next'

报错了:因为这是python2的语法,python3是下面这样

f.next()

 next(f)
Out[21]: 1

next(f)
Out[22]: 1

next(f)
Out[23]: 2

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值