2 13 5 1 2 1 2 3 1 2 3 1 3 2 1 2 1 2 3 1 3 13 5 1 2 1 2 3 1 2 3 1 3 2 1 2 1 2 3 2 1
6 -1
//109MS 1252K
#include<stdio.h>
#include<string.h>
int text[1000007],pattern[10007];
int next[10007],n,m;
void pre()
{
next[0]=-1;
int j=-1;
for(int i=1;i<m;i++)
{
while(j>=0&&pattern[j+1]!=pattern[i])j=next[j];
if(pattern[j+1]==pattern[i])j++;
next[i]=j;
}
}
int kmp()
{
int ans=0,j=-1;
for(int i=0;i<n;i++)
{
while(j>=0&&pattern[j+1]!=text[i])j=next[j];
if(pattern[j+1]==text[i])j++;
if(j==m-1)return i-m+2;//返回第一次找到的位置
}
return -1;//找不到
}
int main()
{
int t;
scanf("%d",&t);
while(t--)
{
scanf("%d%d",&n,&m);
for(int i=0;i<n;i++)
scanf("%d",&text[i]);
for(int i=0;i<m;i++)
scanf("%d",&pattern[i]);
pre();
printf("%d\n",kmp());
}
return 0;
}
HDU 1711 Number Sequence KMP入门,布布扣,bubuko.com
HDU 1711 Number Sequence KMP入门
原文:http://blog.csdn.net/crescent__moon/article/details/21987955