KMP子串匹配

分为两个操作:

1.求next数组/longestPrefix数组

2.kmp字符串匹配

模板:

cpp 复制代码
#include <iostream>
#include <vector>
#include <string>
using namespace std;

vector<int> computePrefix(string pat) {
    int m = pat.size();
    vector<int> longestPrefix(m);
    for(int i = 1, k = 0; i < m; i ++ ) {
        while(k > 0 && pat[i] != pat[k]) {
            k = longestPrefix[k - 1];
        }   
        if(pat[i] == pat[k]) {
            longestPrefix[i] = ++k;
        } 
        else {
            longestPrefix[i] = k;
        }    
    }
    return longestPrefix;
}

void kmp(string text, string pat) {
    int n = text.size();
    int m = pat.size();
    vector<int> longestPrefix = computePrefix(pat);
       
    for(int i = 0, k = 0; i < n; i ++ ) {
        while(k > 0 && pat[k] != text[i]) {
            k = longestPrefix[k - 1];
        }
        if(pat[k] == text[i]) {
            k ++;
        }
        if(k == m) {
            cout << i - m + 1 + 1 << endl;
            k = longestPrefix[k - 1];
        }
    }
}
int main() {
    string text, pat;
    cin >> text >> pat;

    kmp(text, pat);

    return 0;
}
相关推荐
XianxinMao4 小时前
RLHF技术应用探析:从安全任务到高阶能力提升
人工智能·python·算法
hefaxiang4 小时前
【C++】函数重载
开发语言·c++·算法
exp_add35 小时前
Codeforces Round 1000 (Div. 2) A-C
c++·算法
查理零世5 小时前
【算法】经典博弈论问题——巴什博弈 python
开发语言·python·算法
神探阿航5 小时前
第十五届蓝桥杯大赛软件赛省赛C/C++ 大学 B 组
java·算法·蓝桥杯
皮肤科大白6 小时前
如何在data.table中处理缺失值
学习·算法·机器学习
不能只会打代码7 小时前
蓝桥杯例题一
算法·蓝桥杯
OKkankan8 小时前
实现二叉树_堆
c语言·数据结构·c++·算法
ExRoc9 小时前
蓝桥杯真题 - 填充 - 题解
c++·算法·蓝桥杯
利刃大大9 小时前
【二叉树的深搜】二叉树剪枝
c++·算法·dfs·剪枝