python用迭代器的方式实现斐波那契数列

__metaclass__ = type
class Fibs:
    def __init__(self):
        self.a = 0
        self.b = 1
    def next(self):
        self.a, self.b = self.b, self.a + self.b
        return self.a
    def __iter__(self):
        return self

fibs = Fibs()
for f in fibs:
    if f < 1000:
        print f,
    else:
        print f, 'VOER'
        break
    
    
__iter__方法返回一个迭代器(iteratior), 所谓的迭代器就是具有next方法的对象,在调用next方法时,迭代器会返回它的下一个值。
1 1 2 3 5 8 13 21 34 55 89 144 233 377 610 987 1597 OVER


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值