KMP字符串查找算法
KMP算法的重點是尋找next數組,程序如下:
#include <iostream>include <string>
include <vector>
using namespace std;
class Solution { public: int KMPSearch(string text, string pattern, vector<int> next) { int i = 0; int j = 0; while (i<text.size() && j<int(pattern.size())) { if (j == -1 || pattern[j] == text[i]) { i++; j++; } else { j = next[j]; } }
if ( j == pattern.size()) return i - j; else return -1; } void GetNext(string pattern, vector<int>& next) { next[0] = -1; int start = -1; int end = 0; while (end < pattern.size() - 1) { if (start == -1 || pattern[start] == pattern[end]) { ++start; ++end; next[end] = start; } else { start = next[start]; } } }};
int main() { Solution sol; vector<int> next(7, 0); string text("AAAAABBC ABCDAB ABCDABBDCDABDE ABCDABD"); string pattern("ABCDABD"); sol.GetNext(pattern, next); cout << sol.KMPSearch(text, pattern, next) << endl; }</pre>
 本文由用戶 fefre  自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
                         轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
                         本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!