日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

python显示1000以内的斐波拉契数列_python实现斐波那契数列

發布時間:2025/3/19 python 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python显示1000以内的斐波拉契数列_python实现斐波那契数列 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

首先想到的是用遞歸來解決

求100內的斐波那契數列:

def diGui(num=100):

a,b = 0,1

# 為了方便看打印,我就用list存一下

lit = []

while a < num:

# print(a)

lit.append(a)

a, b = b,a+b

print(lit)

diGui()

# 打印輸出為

[0, 1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89]

# 求1000內的

diGui(1000)

[0, 1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144, 233, 377, 610, 987]

遞歸是比較容易解決,但是這個對內存很不友好,要是后面求10000,100000,甚至更大的呢!

所以就想到可以用python的生成器,如果一個函數中有yield關鍵字,那他就是一個生成器(generator).

import sys

# 這里其實和上面的遞歸寫法很類似,只需要把print(a)換成yeild就行

def generator(num=100):

a,b = 0,1

while a < num:

# print(a)

yield a

a, b = b,a+b

# 注意:這里的g是一個生成器對象

g = generator()

print(type(g))

# 然后我調用next()方法取值

while True:

print(next(g))

# 重復調用next()方法,但是這里會拋異常,因為重復調用next()方法,直到結束

Traceback (most recent call last):

File "D:/xxxxxxx.py", line 60, in

print(next(g))

StopIteration

0

1

1

2

3

5

8

13

21

34

55

89

Process finished with exit code 1

# 所以我們可以try一下,捕獲它,讓程序正常結束

while True:

try:

# print(next(g))

n = next(g)

if n < 100:

print(n)

except StopIteration:

print('沒有了!')

sys.exit() # sys是python的模塊,需要import

# 最后輸出

0

1

1

2

3

5

8

13

21

34

55

89

沒有了!

總結

以上是生活随笔為你收集整理的python显示1000以内的斐波拉契数列_python实现斐波那契数列的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。