题解 | #String Matching#

String Matching

https://www.nowcoder.com/practice/00438b0bc9384ceeb65613346b42e88a

#include <iostream>
using namespace std;
int nextt[1000000];
string a,b;//文本串,模式串

void GetNext(int m)
{
    nextt[0]=-1;
    int i=-1;
    int j=0;
    while(j<m)
    {
        if(i==-1||b[i]==b[j])
        {
            i++;j++;
            nextt[j]=i;
        }
        else {
            i=nextt[i];
        }
    }
}
int KMP(int m,int n)
{
    int i=0;//文本串
    int j=0;//模式串
    int num=0;
    GetNext(m);
    while(i<n)
    {
        if(a[i]==b[j]||j==-1)
        {
            i++;j++;
        }
        else {
            j=nextt[j];
        }
        if(j==m)//模式串的下标最大为m-1,j必须重新赋值
        {
            num++;
            j=nextt[j];
        }
    }
    return num;
}

int main() {
    while (cin >> a >> b) { 
        int n=a.size();
        int m=b.size();
        int num=KMP(m,n);
        cout<<num<<endl;
    }
}

全部评论

相关推荐

不愿透露姓名的神秘牛友
07-11 11:16
点赞 评论 收藏
分享
小浪_Coding:找硬件测试,也可兼顾软测欧, 简历还可以的 ,注意排版,项目写的有条理一点, 然后个人技能多加点, 润色好简历之后就开始沟通海投了,深圳,东莞这边做硬件相关的公司还不少, 医疗类,仪器类的都可以尝试
点赞 评论 收藏
分享
07-09 19:25
门头沟学院 Java
这是要把每一个投校招的都开盒吗?
26届之耻将大局逆转:裁人的时候一次性追回餐费
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务