KMP字串匹配演算法

2021-06-11 10:45:09 字數 900 閱讀 2766

kmp核心思想:計算模式串的next陣列,主串的索引在比較的過程中不回朔

#ifndef kmp_h_

#define kmp_h_

class kmp

;#endif

#include "kmp.h"

#include #include #include using namespace std;

int kmp::calcu(char* pmain,char* pchild,int mainlength,int childlength)

/* pmain----被比較串。

* pchild-----待比較串

* mainlength----pmain的長度

* childlength-----pchild的長度

*/void kmp::getnext(char* pstr,int length,int* kmpnext)

/* pstr---------模式串

* length-----串長度

* kmpnext-----要輸出的next陣列,記錄當模式串中對應位布匹配時,主串當前位再和模式串的那一未比較

* */ else

j=kmpnext[j];

}}

應用舉例:

1.求兩個字串的最大公共子串:

eg:s1=123abcd456 和s2=456abcd123

按s2字尾串由短到長,分別求每個字尾串與s1匹配時的最大匹配長度。最長匹配的那部分就是最大公共字串。

2.進一步擴充套件就是求s=123abccba34的最長回文。

此問題等價於:s1=123abccba34 s2=34abccba321的最大公共子串。

KMP演算法 字串匹配

kmp演算法基本思想 我們在用常規的思想做 字串匹配時候是 如 對如 字元如果 t abab 用p ba 去匹配,常規思路是 看 t 第乙個元素 a 是否 和p 的乙個 b 匹配 匹配的話 檢視各自的第二個元素,不匹配 則將 t 串的 第二個元素開始 和 p 的第乙個匹配,如此 一步一步 的後移 來...

KMP字串匹配演算法

在介紹kmp演算法之前,先介紹一下bf演算法。一.bf演算法 bf演算法是普通的模式匹配演算法,bf演算法的思想就是將目標串s的第乙個字元與模式串p的第乙個字元進行匹配,若相等,則繼續比較s的第二個字元和p的第二個字元 若不相等,則比較s的第二個字元和p的第乙個字元,依次比較下去,直到得出最後的匹配...

字串匹配演算法KMP

kmp演算法的原理,這裡我不寫,建議參考 這篇部落格寫的非常好,以本人的能力只能寫出更爛的解釋 所以就不再多此一舉了,下面僅僅給出兩段 分別用c 和python寫的 都已經編譯通過 希望能對大家有所幫助 c include include using namespace std bool pifun...