[模板] 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;
}
上一篇:C语言的函数指针数组(好绕啊~看完这篇估计就通关了)


下一篇:linux运维、架构之路-Hadoop完全分布式集群搭建