Page List

Search on the blog

2011年3月4日金曜日

KMP -- String Search Algorithm --

Today I'm gonna write about KMP algorithm, which is an algorithm for string search designed by three researchers: Knuth, Morris and Pratt.

There are several string search algorithm out there. I know about BM method and KR method besides KMP.
But it seems like KMP method is the most common, and it is used more often than other algorithm.

The idea is quite simple.
This Wikipedhia page explains it quite well:

But it's not smart to implement the algorithm exactly same way as it's mentioned in the site above. You're so near but so far if you have a good grasp of the algorithm but cannot implement it well.

There's simpler implementation many algorithmers are using.
I was thrilled when I saw this implementation first. So simple and so smart!!
Here's my solution to a POJ problem with the implementation:


  1. char text[1000000+1];  
  2. char word[10000+1];  
  3. int fail[10000+1];  
  4.   
  5. void mkFail() {  
  6.     int n = strlen(word);  
  7.     int j = fail[0] = -1;  
  8.   
  9.     for (int i = 1; i <= n; i++) {  
  10.         while (j >= 0 && word[j] != word[i-1])  
  11.             j = fail[j];  
  12.         fail[i] = ++j;  
  13.     }  
  14. }  
  15.   
  16. int kmp() {  
  17.     int n = strlen(word);  
  18.     int l = strlen(text);  
  19.     int cnt = 0;  
  20.   
  21.     for (int i = 0, m = 0; m < l; m++) {  
  22.         while (i >= 0 && word[i] != text[m])  
  23.             i = fail[i];  
  24.         if (++i >= n) {  
  25.             ++cnt;  
  26.             i = fail[i];  
  27.         }  
  28.     }  
  29.     return cnt;  
  30. }  
  31.   
  32. int main() {  
  33.     int n;  
  34.   
  35.     scanf("%d", &n);  
  36.   
  37.     while (n--) {  
  38.         scanf("%s", word);  
  39.         scanf("%s", text);  
  40.         mkFail();  
  41.         printf("%d\n", kmp());  
  42.     }  
  43.   
  44.     return 0;  
  45. }  










0 件のコメント:

コメントを投稿