基礎(chǔ)版(list方法)
# 比較占內(nèi)存 w = int(input("輸入一個(gè)數(shù)字還你一個(gè)斐波那契數(shù)列:")) list_res = [] def list_n(n): if n>=3: res=list_n(n-1)+list_n(n-2) else: res=1 return res print("開(kāi)始") for i in range(0,w): list_res.append(list_n(i+1)) print(list_res)
升級(jí)版
# 比較占內(nèi)存 num =int(input("輸入一個(gè)數(shù)字還你一個(gè)斐波那契數(shù)列v2.0:")) list_nums=[1,1] def calculate(num,list_nums): i = 0 if num>2: while i < num: list_nums.insert(i+2,list_nums[i]+list_nums[i+1]) i+=1 else: print("數(shù)列已生成") print(list_nums) return list_nums[num-1] else: return list_nums[0] res = calculate(num,list_nums) print("="*50) print("第%s個(gè):%s"%(num,res))
最實(shí)用版(解包的方式)
#省內(nèi)存 def fbnq(n): a,b=1,1 if n==1 or n ==2: return 1 else: i=3 while i<=n: a,b=b,a+b i+=1 return b print(fbnq(int(input("輸入一個(gè)數(shù):"))))
迭代器版
"""實(shí)現(xiàn)斐波那契數(shù)列""" class feibo(object): def __init__(self, length): self.num1 = 0 self.num2 = 1 self.num = self.num1 self.length = length self.index = 0 def __iter__(self): return self def __next__(self): self.num = self.num1 while True: if self.index == self.length: raise StopIteration self.num1, self.num2 = self.num2, self.num1+self.num2 self.index += 1 return self.num myfbnq = feibo(10) # print(list(myfbnq)) # 指針位置已到最后一位 for i in myfbnq: print(i)
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號(hào)聯(lián)系: 360901061
您的支持是博主寫(xiě)作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對(duì)您有幫助就好】元
