题解 | #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;
    }
}

全部评论

相关推荐

湫湫湫不会java:先投着吧,大概率找不到实习,没实习的时候再加个项目,然后把个人评价和荣誉奖项删了,赶紧成为八股战神吧,没实习没学历,秋招机会估计不多,把握机会。或者说秋招时间去冲实习,春招冲offer,但是压力会比较大
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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