603【模板】KMP 算法


视频链接:603【模板】KMP 算法_哔哩哔哩_bilibili

 

Luogu P3375【模板】KMP字符串匹配

#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;

const int N = 1000010;
int m, n;
char S[N], P[N];
int ne[N];

int main(){
    cin >> S+1 >> P+1;
    m = strlen(S+1), n = strlen(P+1);
    // 计算next函数
    ne[1] = 0;
    for(int i = 2, j = 0; i <= n; i ++){
        while(j && P[i] != P[j+1]) j = ne[j];
        if(P[i] == P[j+1]) j ++; 
        ne[i] = j;
    }
    // KMP匹配
    for(int i = 1, j = 0; i <= m; i ++){
        while(j && S[i] != P[j+1]) j = ne[j];
        if(S[i] == P[j+1]) j ++;
        if(j == n) printf("%d\n", i-n+1);
    }
    for(int i = 1; i <= n; i ++)
        printf("%d ", ne[i]);
    return 0;
}

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM