例题4.6Number Sequence

#include <iostream>
using namespace std;

int nn[1000000];
int mm[10000];
int nextt[10000];//不能命名为next,可能和C++内置函数重名了 

void GetNext(int m)
{
int i,j;
j=0;i=-1;
nextt[0]= -1;
while(j<m)
{
if(i==-1||mm[i]==mm[j])
{
i++;j++;
nextt[j]=i;
}
else
{
i=nextt[i];
}
}

return ;
}

int KMP(int n,int m)
{
GetNext(m);
int i=0;
int j=0;
while(i<n &amp;&amp; j<m)
{
if(j==-1 || nn[i]==mm[j])
{
i++;j++;
}
else
{
j=nextt[j];
}
}

if(j==m)
{
return i-j+1;
}
else
{
return -1;
}
}

int main()
{
int num;cin>>num;
int n,m;
for(int i=1;i<=num;i++)
{
cin>>n>>m;
for(int j=0;j<n;j++)
cin>>nn[j];
for(int k=0;k<m;k++)
cin>>mm[k];

cout<<KMP(n,m)<<endl;
}
return 0;
 }
全部评论

相关推荐

不愿透露姓名的神秘牛友
07-09 12:23
转人工😡
门口唉提是地铁杀:五次握手了
点赞 评论 收藏
分享
流浪的神仙:无恶意,算法一般好像都得9硕才能干算法太卷啦
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-09 16:15
我应届生,去年10月份开始在这家公司实习,到今年10月份正好一年想(实习+试用期),在想要不要提前9月份就离职,这样好找工作些,但又差一个月满一年,又怕10月份国庆回来离职,容易错过了下半年的金九银十,到年底容易gap到年后
小破站_程序员YT:说这家公司不好吧,你干了快一年 说这家公司好吧,你刚毕业就想跑路说你不懂行情吧,你怕错过金九银十说 你懂行情吧,校招阶段在实习,毕业社招想换工作 哥们,我该怎么劝你留下来呢
应届生,你找到工作了吗
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

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