LoginSignup
1
2

More than 5 years have passed since last update.

ジェネレータとイテレータでフィボナッチ数列を計算する

Posted at
  • yieldはジェネレータ関数のループの中に書く
  • ジェネレータ関数のループ以外の部分は1回しか呼び出されない
  • ジェネレータ関数はイテレータを返す
  • イテレータからnextメソッドによって繰り返し要素を取得できる
  • nextメソッドを呼べば呼ぶほど無限に値を生成できる
fibonacci.py
#!/usr/bin/python

# ジェネレータを定義する
def fibonacci():
    a = 0 # 初期設定
    b = 1 # 初期設定

    while True:
        yield b # ジェネレータ関数のループの中にyieldを書く
        a, b = b, a + b

# ジェネレータはイテレータを返す
fib = fibonacci()

#リスト内包表記でイテレータの各要素を順に配列に入れる
fib_array = [fib.next() for i in range(10)] 

print fib_array
  • 計算結果
[1, 1, 2, 3, 5, 8, 13, 21, 34, 55]
1
2
1

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
1
2