项目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 "", line 1, in
    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

 

你可能感兴趣的:(python,数据结构)