好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > Python實現求解斐波那契第n項的解法(包括矩陣乘法+快速冪)

Python實現求解斐波那契第n項的解法(包括矩陣乘法+快速冪)

熱門標簽:電話機器人貸款詐騙 京華圖書館地圖標注 佛山通用400電話申請 看懂地圖標注方法 淮安呼叫中心外呼系統如何 打印谷歌地圖標注 電話外呼系統招商代理 廣東旅游地圖標注 蘇州人工外呼系統軟件

斐波那契數列

首先我們來定義一下斐波那契數列:

即數列的第0項:

算法一:遞歸

遞歸計算的節點個數是O(2ⁿ)的級別的,效率很低,存在大量的重復計算。

比如:

f(10) = f(9) + f(8)

f(9) = f(8) + f(7) 重復 8

f(8) = f(7) + f(6) 重復 7

時間復雜度是O(2ⁿ),極慢

def F1(n):
    if n = 1: return max(n, 0)  # 前兩項
    return F1(n-1)+F1(n-2)  # 遞歸

算法二:記憶化搜索

開一個大數組記錄中間結果,如果一個狀態被計算過,則直接查表,否則再遞歸計算。

總共有 n 個狀態,計算每個狀態的復雜度是 O(1),所以時間復雜度是 O(n)。但由于是遞歸計算,遞歸層數太多會爆棧。

res = [None]*100000
def F2(n):
    if n = 1: return max(n, 0)
    if res[n]: return res[n]  # 如果已存在則直接查找返回結果
    res[n] = F2(n-1)+F2(n-2)  # 不存在則計算
    return res[n]

算法三:遞推

開一個大數組,記錄每個數的值。用循環遞推計算。

總共計算 n 個狀態,所以時間復雜度是 O(n)。但需要開一個長度是 n 的數組,內存將成為瓶頸。

def F3(n):
    if n = 1: return max(n, 0)
    res = [0, 1]
    for i in range(2,n+1):
        res.append(res[i-1]+res[i-2])
    return res[n]

算法四:遞歸+滾動變量

比較優秀的一種解法。仔細觀察我們會發現,遞推時我們只需要記錄前兩項的值即可,沒有必要記錄所有值,所以我們可以用滾動變量遞推。

時間復雜度還是 O(n),但空間復雜度變成了O(1)。

def F4(n):
    if n = 1: return max(n, 0)
    fn, f0, f1 = 0, 1, 0  # fn為最終結果,f0為第0項,f1為第一項,
    for i in range(2, n+1):
        fn = f0 + f1  # 前兩項和
        f0, f1 = f1, fn  # 遞推變量
    return fn

算法五:矩陣乘法+快速冪

利用矩陣運算的性質將通項公式變成冪次形式,然后用平方倍增(快速冪)的方法求解第 n 項。

先說通式:

利用數學歸納法證明:

這里的a0,a1,a2是對應斐波那契的第幾項

證畢。

所以我們想要的得到An,只需要求得Aⁿ,然后取第一行第二個元素即可。

如果只是簡單的從0開始循環求n次方,時間復雜度仍然是O(n),并不比前面的快。我們可以考慮乘方的如下性質,即快速冪:

這樣只需要 logn 次運算即可得到結果,時間復雜度為 O(logn)

def mul(a, b):  # 首先定義二階矩陣乘法運算
    c = [[0, 0], [0, 0]]  # 定義一個空的二階矩陣,存儲結果
    for i in range(2):  # row
        for j in range(2):  # col
            for k in range(2):  # 新二階矩陣的值計算
                c[i][j] += a[i][k] * b[k][j]
    return c
def F5(n):
    if n = 1: return max(n, 0)
    res = [[1, 0], [0, 1]]  # 單位矩陣,等價于1
    A = [[1, 1], [1, 0]]  # A矩陣
    while n:
        if n  1: res = mul(res, A)  # 如果n是奇數,或者直到n=1停止條件
        A = mul(A, A)  # 快速冪
        n >>= 1  # 整除2,向下取整
    return res[0][1]

總的來說不是很難,適合擴展思路。更多關于Python的資料請關注腳本之家其它相關文章!希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Python:合并兩個numpy矩陣的實現
  • python實現由數組生成對稱矩陣
  • Python 如何求矩陣的逆
  • python用分數表示矩陣的方法實例
  • Python numpy大矩陣運算內存不足如何解決
  • Python計算矩陣的和積的實例詳解
  • python 如何將兩個實數矩陣合并為一個復數矩陣

標簽:中山 湖州 呼和浩特 股票 畢節 衡水 駐馬店 江蘇

巨人網絡通訊聲明:本文標題《Python實現求解斐波那契第n項的解法(包括矩陣乘法+快速冪)》,本文關鍵詞  Python,實現,求解,斐波,那契,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Python實現求解斐波那契第n項的解法(包括矩陣乘法+快速冪)》相關的同類信息!
  • 本頁收集關于Python實現求解斐波那契第n項的解法(包括矩陣乘法+快速冪)的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 波多野结衣伦理在线观看| 欧美一级e级太片| 一二三四日本手机高清视频| 再深点灬舒服灬太大了添阿宾视频| 日韩女同久久精品A片| 无遮挡1000部拍拍拍欧美劲爆| 国产精品入口麻豆午夜| 免费无码又爽又黄又刺激网站简爱 | 骚虎影库| 99??高潮片免费视频小水水| poren18日本老师hd| 色戒未删版在线观看| 两根双龙玩弄尿喷H肉重口| 91?精彩刺激对白| 国产亚洲精品久久777777| 精品免费国产二区三区四区使用方法 | 91久久青草精品38国产_一级A爱大片夜夜夜夜春 | 三上悠亚视频在线| 精品免费大国偷自产在线Av片 | 阿阿阿受不了了太大了视频| 片多多电影电视剧影视剧| gayfreevideos亚洲男男| 91在线无码精品秘?入口不卡| 久久精品只有这里有| 黄网站色年片在线观看| 国产欧美日韩精品专区黑人| a4yy影院| 五十路熟女人妻一区二区| 啪啪h高文小说| 日本三级电影免费播放| 寡妇高潮一级毛片免费观看A片| 秘?羞羞视频观看免费版| 成人H漫画精精一区二区器材| 草草免费观看视频在线| 国产区视频在线观看| 乱系列人妻晓红| 97影院理论片在线观看免费| 美女视频网站视频免费下载| 餐桌下顶撞h厨房play| 美女露100%胸| 尤物AV天堂一区二区在线观看|