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