Oulipo HDU - 1686

kmp模板题

#include<iostream>
#include<algorithm>
#include<cstring>
using namespace std;
const int max_n = 1e6+100;
int net[11000];
void getnext(int p[],int psize){
    net[0]=-1;p[psize]=500;
    for (int i=0,j=-1;i<psize;){
        if (j==-1||p[i]==p[j]){
            ++i;++j;
            if (p[i]!=p[j])
                net[i]=j;
            else net[i]=net[j];
        }
        else j = net[j];
    }

}

int kmp(int s[],int ssize,int p[],int psize){
    int res = 0;
    for (int i=0,j=0;i<ssize;){
        if (j==-1||s[i]==p[j])++i,++j;
        else j = net[j];
        if (j==psize){
            ++res;
            j = net[j];
        }
    }return res;
}
int p[11000];
int s[max_n];
char ss[max_n];
int main(){
    int T;scanf("%d",&T);
    while (T--){
        scanf("%s",ss);
        int m = strlen(ss);
        for (int i=0;i<m;++i)p[i]=(int)ss[i];
        scanf("%s",ss);
        int n = strlen(ss);
        for (int i=0;i<n;++i)s[i]=(int)ss[i];
        getnext(p,m);
        printf("%d\n",kmp(s,n,p,m));
    }
}
Kuangbin题单详解(kmpManacher) 文章被收录于专栏

刷Kuangbin题

全部评论

相关推荐

有工作后先养猫:太好了,是超时空战警,我们有救了😋
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务