[模板] KMP字符串匹配标准代码

之前借鉴了某个模板的代码。我个人认为这份代码写得很好。值得一背。

#include<bits/stdc++.h>
using namespace std;
const int N=100010;
int Next[N];

int main(){
    string A,B;
    cin>>A>>B;
    int lena=A.size(),lenb=B.size();
    int t1=0,t2=-1;
    Next[0]=-1;
    while(t1<lenb){
        if(t2==-1||B[t1]==B[t2]){
            t2++;
            Next[++t1]=t2;
        }
        else t2=Next[t2];
    }
    int i,j,ans=-1;
    i=j=0;
    while(i<lena){
        if(j==-1||A[i]==B[j])i++,j++;
        else j=Next[j];
        if(j==lenb){
            printf("%d\n",i-lenb+1);
            j=Next[j];
        }
    }
    for(int i=1;i<=lenb;i++){
        if(i>1)putchar(' ');
        printf("%d",Next[i]);
    }
    return 0;
}
posted @ 2017-11-07 07:42  NagaseIori  阅读(205)  评论(0编辑  收藏  举报