HDU-1686-KMP-水题

时间:2024-07-27 21:08:14

纯KMP

 #include <cstdio>
#include <algorithm>
#include <cstring>
#include <ctype.h>
#include <cstdlib>
#include <stack>
#include <set>
#include <map>
#include <queue>
#include <string>
#include <cmath> using namespace std; int M,N,T;
char A[],B[];
int f[]; void getFail(char *P)
{
f[] = ;f[] = ;
for(int i=;i<M;i++)
{
int j = f[i];
while(j && P[i] != P[j]) j = f[j];
f[i+] = P[i] == P[j] ? j+ : ;
}
} int find(char *T,char *P)
{
getFail(P);
int j=;
int ans = ;
for(int i=;i<N;i++)
{
while(j && T[i] != P[j]) j = f[j];
if( T[i] == P[j] ) j++;
if(j == M) ans++;
}
return ans;
} int main()
{
scanf("%d",&T);
while(T--)
{
//for(int i=0;i<N;i++) scanf("%c",&A[i]);
//for(int i=0;i<M;i++) scanf("%c",&B[i]);
scanf("%s %s",B,A);
N = strlen(A);M = strlen(B);
printf("%d\n",find(A,B));
}
}