久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術文章
文章詳情頁

利用Python實現(xiàn)斐波那契數(shù)列的方法實例

瀏覽:89日期:2022-07-16 11:50:12

今天我們來使用Python實現(xiàn)遞歸算法求指定位數(shù)的斐波那契數(shù)列

首先我們得知道斐波那契數(shù)列是什么?

斐波那契數(shù)列又叫兔子數(shù)列 斐波那契數(shù)列就是一個數(shù)列從第三項開始第三項的值是第一項和第二項的和依次類推

其次我們再來看遞歸算法是什么?

遞歸就是如果函數(shù)(子程序)包含了對其自身的調(diào)用,該函數(shù)就是遞歸的

話不多說上案例:

第一種方法:不使用遞歸算法

#首先定義一個新的列表來儲存最后的結(jié)果new_list = []# 然后讓用戶輸入指定位數(shù)my_put = int(input('請輸入使用遞歸算法求指定位數(shù)的斐波那契數(shù)列的位數(shù): '))# 利用for循環(huán)來遍歷數(shù)組for idx in range(my_put): # 利用if判斷第使得第一位和第二位都為1 if idx == 0: new_list.append(1) elif idx == 1: new_list.append(1) # 第三次的時候 當idx等于二的時候 然后第三項的話 應該的是第一項和第二項的和第一項的索引是0 第二項的索引是1 #但是上面if判斷以后 下面從idx為二的時候開始 # 所以應該是索引為idx-2和索引為idx-1的相加得出第三項 else: new_list.append(new_list[idx - 2] + new_list[idx - 1])# 最后輸出最后的數(shù)列print(new_list)

第二種方法:使用遞歸算法

def get_num(n): # 獲取斐波拉契數(shù)列中第n個數(shù)字的值 if n == 1 or n == 2: return 1 return get_num(n - 1) + get_num(n - 2)# 把獲取的斐波拉契數(shù)字存放到列表中nums = []for i in range(1, 9): nums.append(get_num(i)) # get_num獲得一個斐波拉契數(shù)字print(nums)

兩種方法最后的運行結(jié)果都為:

請輸入使用遞歸算法求指定位數(shù)的斐波那契數(shù)列的位數(shù): 9[1, 1, 2, 3, 5, 8, 13, 21, 34]

總結(jié)

到此這篇關于利用Python實現(xiàn)斐波那契數(shù)列的文章就介紹到這了,更多相關Python實現(xiàn)斐波那契數(shù)列內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持好吧啦網(wǎng)!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 安西县| 郓城县| 聊城市| 康马县| 青州市| 琼结县| 金沙县| 秀山| 清河县| 柯坪县| 延安市| 抚宁县| 芦山县| 九江市| 湟源县| 新宁县| 台北县| 阳江市| 轮台县| 樟树市| 仪陇县| 文成县| 桃江县| 吉木乃县| 通化市| 岳西县| 渝北区| 江口县| 深圳市| 南阳市| 许昌市| 祥云县| 南华县| 阿克陶县| 哈密市| 乃东县| 常山县| 石柱| 偃师市| 襄垣县| 德江县|