KMP演算法 字串匹配

2021-06-07 15:16:59 字數 1259 閱讀 4749

kmp演算法基本思想:

我們在用常規的思想做 字串匹配時候是 如 對如 字元如果 t = abab 用p = ba 去匹配,常規思路是 看 t 第乙個元素 a 是否 和p 的乙個 b 匹配 ,匹配的話 檢視各自的第二個元素,不匹配 則將 t 串的 第二個元素開始 和 p 的第乙個匹配,如此 一步一步 的後移 來進行逐個匹配 這樣效率不是很高,對於 kmp 演算法,其根本就是對 匹配模式串 p 進行 預處理當在匹配的時候可以 選擇 聯絡向 t 後移動幾步進行匹配,而不需只是逐步移動》

如 對於 用 p[1:m] 去匹配 t[1:n ] 當 p[1:i ] 與 t[1+s : j] ( j = i+s) 匹配 ,但是 t[j+1]  != p[i+1] 如此 ,我們必須將 i+s 的 t 起始匹配位置 向後移動,(常規是移動一步進行匹配),如果我們知道 對於 p 的已經匹配子串 p[1:i] 有 前 q 個元素 可以是 p[1:i]的字首,也是 串 p[1:i] 的字尾那麼 我們可以 從 p 的 i+1 的位置開始,和 j+1 的位置開始匹配,也就是所 可以向後移動 i-q 步如後進行匹配。

詳情看演算法導論:p568

**如下:

#include #include#includeusing namespace std;

int fail[100];

int *pre;

// 預處理 函式

void prefix_function(const char const *p,int m)

if( p[k] == p[q-1])

pre[q] = k;

} for( int i =1 ;i <=m ;i++)

if( t[i] == p[q])

if( q == m)

i = j = 0;

while( str[i] && pat[j] )

if( pat[j] ) return -1;

else return i-j;

} int main (void) {

char const *t;

char const *p;

int n,m;

string t1;

string p1;

cin>>t1>>p1;

n = t1.length();

m = p1.length();

t = t1.c_str();

p = p1.c_str();

pre = new int[m+1];

cout<

KMP字串匹配演算法

kmp核心思想 計算模式串的next陣列,主串的索引在比較的過程中不回朔 ifndef kmp h define kmp h class kmp endif include kmp.h include include include using namespace std int kmp calcu...

KMP字串匹配演算法

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

字串匹配演算法KMP

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