欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python實(shí)現(xiàn)KPM算法詳解

 更新時(shí)間:2021年12月08日 09:37:53   作者:小星博博  
大家好,本篇文章主要講的是Python實(shí)現(xiàn)KPM算法詳解,感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下,方便下次瀏覽

知識(shí)點(diǎn)說(shuō)明:

先說(shuō)前綴,和后綴吧

比如有一個(gè)串:abab

則在下標(biāo)為3處的(前綴和后綴都要比下標(biāo)出的長(zhǎng)度小1,此處下標(biāo)為3出的長(zhǎng)度是4)

前綴為:a,ab,aba

后綴為:b,ba,bab

一、要獲取KPM算法的next[]數(shù)組

簡(jiǎn)單說(shuō)一下原理吧,首先k,用來(lái)存放前綴的下標(biāo),首先初始化j=0(j用來(lái)表示模式串的下標(biāo),一直去模式串的每一位與前面的進(jìn)行比較,如果相等,則記錄下當(dāng)前位置與前面的哪個(gè)位置相同,我們這里主要是要記錄相同位置的下一個(gè)位置,就是不相同的位置,從不相同的位置開(kāi)始比較,就是回溯到不相同位置,所以這里在t[j]==t[k]成立的時(shí)候要j+1,為了比較下一個(gè)位置是否相同,k也要+1),模式串從0開(kāi)始,k=-1,next[0]=-1第一個(gè)位置賦默認(rèn)值-1;

此處串采用=“abab”

第一次循環(huán):

判斷k是否等于-1,如果等于則,j和k都+1,

此時(shí)j=1,k=0,next[1]=0,也就是第2個(gè)位置(下標(biāo)1)的回溯位置還是0,因?yàn)榍熬Y的最大長(zhǎng)度必須小于當(dāng)前位置的長(zhǎng)度;

第二次循環(huán):

j=1,k=0,next[1]=0;k已經(jīng)不等于-1了,判斷t[j]==t[k],t[1]==t[0],t[1]="b",t[0]="a",不相等

執(zhí)行else:

k=next[0]=-1

第三次循環(huán):

k==-1

j和k都+1,j=2,k=0,next[2]=0

第四次循環(huán):

k不等于-1,判斷t[2]==t[0],t[2]=“a”=t[0]=“a”,成立

j和k都+1,j=3,k=1,next[3]=1

此時(shí)next=[-1,0,0,1],next[3]=1表示在next[3]處發(fā)生不匹配時(shí),也就是模式串下標(biāo)為3時(shí)為“b”,說(shuō)明前面aba都是和目標(biāo)串都匹配,所以模式串不匹配位置前面的串a(chǎn)ba一定與目標(biāo)串不匹配位置前面的前3個(gè)值相等,也就是aba,所以此刻,只需要回溯到模式串的1位置,也就是模式串的b,模式串b前面是a,滿足目標(biāo)串的前一個(gè)a。

第五次循環(huán):

k依舊是不等于-1,就是比較上一個(gè)位置后面的兩個(gè)數(shù)再進(jìn)行比較,簡(jiǎn)單的說(shuō),以此取出每一項(xiàng)與第一項(xiàng)比較,如果存在相等的就再比較下一個(gè)與第二項(xiàng)是否相等。

代碼如下:

def GetNext(t, next):
    j, k = 0, -1
    next[0] = -1
    while j < len(t) - 1:
        if k == -1 or t[j] == t[k]:  # 如果k==-1 或者 開(kāi)始位置和結(jié)尾位置有相同的元素
            j, k = j + 1, k + 1  # j和k都加1,當(dāng)前位匹配,則從下一個(gè)位置開(kāi)始匹配,所以k+1;j再進(jìn)行取下一位判斷是否也是匹配,所以也要+1
            next[j] = k  # 當(dāng)前位置要取k項(xiàng)
        else:#如果不相等,再把k置-1,下一次循環(huán)再進(jìn)行+1操作,j這個(gè)位置再存入0,表示無(wú)匹配項(xiàng)
            k = next[k]
    return next

二、KMP函數(shù)

原理和BF算法是一樣的,唯獨(dú)不同的是,當(dāng)模式串與目標(biāo)串不匹配的時(shí)候,不直接回溯模式串,而是根據(jù)模式串的next[]表,查詢要回溯到的位置,直接回溯到模式串的指定位置,KMP算法的核心也就在這里,但是這種方法一般只對(duì)前綴和后綴存在相同元素時(shí),有效果,也就是說(shuō)相同部分是一樣的就不再進(jìn)行比較了,從相同元素的下一個(gè)位置開(kāi)始比較,所以KMP算法最復(fù)雜的部分其實(shí)就是找next[]表,要找出模式串的每一個(gè)位置,是否有相同前綴,如果有則標(biāo)注該相同位置,下次回溯就不用回溯到0這個(gè)位置,可以從不相同位置開(kāi)始。

def KMP(s, t):
    next = [0] * len(t)
    next = GetNext(t, next)
    print(next)
    i, j = 0, 0
    while i < len(s) and j < len(t):
        if j == -1 or s[i] == t[j]:
            i, j = i + 1, j + 1
        else:
            j = next[j]
    if j >= len(t):
        return i - len(t)
    else:
        return -1

完整代碼:

def GetNext(t, next):
    j, k = 0, -1
    next[0] = -1
    while j < len(t) - 1:
        if k == -1 or t[j] == t[k]:  # 如果k==-1 或者 開(kāi)始位置和結(jié)尾位置有相同的元素
            j, k = j + 1, k + 1  # j和k都加1,當(dāng)前位匹配,則從下一個(gè)位置開(kāi)始匹配,所以k+1;j再進(jìn)行取下一位判斷是否也是匹配,所以也要+1
            next[j] = k  # 當(dāng)前位置要取k項(xiàng)
        else:#如果不相等,再把k置-1,下一次循環(huán)再進(jìn)行+1操作,j這個(gè)位置再存入0,表示無(wú)匹配項(xiàng)
            k = next[k]
    return next
 
 
def KMP(s, t):
    next = [0] * len(t)
    next = GetNext(t, next)
    print(next)
    i, j = 0, 0
    while i < len(s) and j < len(t):
        if j == -1 or s[i] == t[j]:
            i, j = i + 1, j + 1
        else:
            j = next[j]
    if j >= len(t):
        return i - len(t)
    else:
        return -1
 
 
if __name__ == '__main__':
    re = KMP('asdfghjsssaaasdfaaaabababcdabd', "ababaaaababaa")
    print(re)

結(jié)果:

到此這篇關(guān)于Python實(shí)現(xiàn)KPM算法詳解的文章就介紹到這了,更多相關(guān)Python KPM算法內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Python matplotlib圖例放在外側(cè)保存時(shí)顯示不完整問(wèn)題解決

    Python matplotlib圖例放在外側(cè)保存時(shí)顯示不完整問(wèn)題解決

    這篇文章主要介紹了Python matplotlib圖例放在外側(cè)保存時(shí)顯示不完整問(wèn)題解決,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • python通過(guò)matplotlib生成復(fù)合餅圖

    python通過(guò)matplotlib生成復(fù)合餅圖

    這篇文章主要介紹了python通過(guò)matplotlib生成復(fù)合餅圖,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-02-02
  • linux下python中文亂碼解決方案詳解

    linux下python中文亂碼解決方案詳解

    這篇文章主要介紹了linux下python中文亂碼解決方案詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-08-08
  • 深入淺析Python中join 和 split詳解(推薦)

    深入淺析Python中join 和 split詳解(推薦)

    這篇文章主要介紹了Python中join 和 split詳解的相關(guān)資料,本文還通過(guò)一個(gè)示例給大家介紹python join 和 split方法 的使用,需要的朋友可以參考下
    2016-06-06
  • Python使用django獲取用戶IP地址的方法

    Python使用django獲取用戶IP地址的方法

    這篇文章主要介紹了Python使用django獲取用戶IP地址的方法,實(shí)例分析了django獲取用戶IP地址過(guò)程中出現(xiàn)的問(wèn)題與對(duì)應(yīng)的解決方法,非常簡(jiǎn)單實(shí)用,需要的朋友可以參考下
    2015-05-05
  • Python學(xué)習(xí)之字典的常用方法總結(jié)

    Python學(xué)習(xí)之字典的常用方法總結(jié)

    這篇文章主要為大家介紹了Python中字典的幾個(gè)常用方法總結(jié),文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)Python字典有一定幫助,需要的可以參考一下
    2022-03-03
  • python生成tensorflow輸入輸出的圖像格式的方法

    python生成tensorflow輸入輸出的圖像格式的方法

    本篇文章主要介紹了python生成tensorflow輸入輸出的圖像格式的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-02-02
  • python實(shí)現(xiàn)圖片篩選程序

    python實(shí)現(xiàn)圖片篩選程序

    這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)圖片篩選程序,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-10-10
  • 使用k8s部署Django項(xiàng)目的方法步驟

    使用k8s部署Django項(xiàng)目的方法步驟

    這篇文章主要介紹了使用k8s部署Django項(xiàng)目的方法步驟,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2019-01-01
  • python scipy卷積運(yùn)算的實(shí)現(xiàn)方法

    python scipy卷積運(yùn)算的實(shí)現(xiàn)方法

    這篇文章主要介紹了python scipy卷積運(yùn)算的實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09

最新評(píng)論