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...