KMP算法

KMP算法



一. 应用场景

给定原字符串A, 查找字符串A中是否包含字符串B. 例如:

在字符串A"aassddaassffaa"中查找是否包含字符串B"aassf" ?

二. KMP算法

核心思想: 略 (去百度,不会写),不过该算法很牛啊, 佩服佩服!.

三. 代码实现

// 第一步:求模式字符串的最长公共前后缀。
void GetPublicPrePostFix(const string& str, vector<int>& output) {
    output.resize(str.size(), 0);
    for (size_t i = 1; i < str.size(); ++i) {
        // 找到那一个可能的最长公共前后缀
        int preFixLength = output[i - 1];
        while (preFixLength != 0 && str[preFixLength] != str[i]) {
            preFixLength = output[output[preFixLength - 1]];
        }
        output[i] = preFixLength + (str[preFixLength] == str[i] ? 1 : 0);
    }
}

// 第二步:在原字符串中查找是否存在模式串
bool hasSubStr(const string& origin, const string& pattern) {

    vector<int> table;
    GetPublicPrePostFix(pattern, table);

    int index = 0;
    for (size_t i = 0; i < origin.size(); ++i) {
        // 找到那个与第i元素相同的下标index, 或者index=0
        while (index > 0 && origin[i] != pattern[index]) {
            index = table[index - 1];
        }
        // 更新index,变成下一轮要对比位置下标。
        if (origin[i] == pattern[index]) {
            index += 1;
        }
        if (index == pattern.size()) {
            return true;
        }
    }
    return false;
}
posted @ 2020-12-26 21:32  殷大侠  阅读(152)  评论(0编辑  收藏  举报