hdu 3336 Count the string(KMP)

本文详细介绍了一道关于KMP算法的应用题,重点讲解了如何通过Next数组来优化字符串匹配过程,并提供了完整的C++实现代码。文章展示了如何利用Next数组记录部分匹配值,从而避免不必要的字符比较。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 一道应用kmp算法中next数组的题目

这其中vis[i]从1加到n

vis[i]=[next[i]]+1;

#include<string.h>
#include<stdlib.h>
#include<stdio.h>
#include<iostream>
#include<algorithm>
using namespace std;
char s[200005];
int b;
int next[200005];
int vis[200005];
void nest(char *s)
{
    next[0]=-1;
    int i=0;
    int j=-1;
    while(i<b)
    {
        if(j==-1||s[i]==s[j])
            {
                i++;
                j++;
                next[i]=j;
            }
        else
            j=next[j];
    }
   // for(i=0;i<=b;i++)
       // printf("%d\n",next[i]);
}
bool kmp(char *s)
{
    int sum=0;
    for(int k=1;k<=b;k++)
    {
        /*int i=0,j=0;
        while(i<b)
        {
            if(j==-1||s[i]==s[j])
            {
                i++;j++;
                if(j==k)
                {
                    sum++;  //printf("%d\n",j);
                    j=next[j];
                }
            }
            else j=next[j];
        }*/
        if(next[k]==0)
            vis[k]=1;
        else
            vis[k]=vis[next[k]]+1;
    }
}
int main()
{
   int a;
   scanf("%d",&a);
   while(a--)
   {
       memset(vis,0,sizeof(vis));
       scanf("%d",&b);
       scanf("%s",s);
        int sum=0;
        nest(s);
        kmp(s);
        for(int i=1;i<=b;i++)
            {sum+=vis[i];
            sum=sum%10007;}
       printf("%d\n",sum);
   }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值