1、在python中使用迭代器生成斐波那契数列
class Fib(object):
def __init__(self, stop):
self.stop = stop
self.current = 0
self.num1 = self.num2 = 1
def __iter__(self):
return self
def __next__(self):
x = self.num1
if self.current < self.stop:
self.current += 1
self.num1, self.num2 = self.num2, self.num1 + self.num2
return x
raise StopIteration
fib = Fib(12)
for i in fib:
print(i)
结果:
1
1
2
3
5
8
13
21
34
55
89
144
2、在python中使用生成器生成斐波那契数列
def Fib(stop):
current = 0
num1 = num2 = 1
while current < stop:
yield num1
num1, num2 = num2, num1 + num2
current += 1
for i in Fib(12):
print(i)
结果:
1
1
2
3
5
8
13
21
34
55
89
144