题目描写叙述
以前。ZYJ同学非常喜欢password学。有一天,他发现了一个非常长非常长的字符串S1。他非常好奇那代表着什么,于是奇妙的WL给了他还有一个字符串S2。可是非常不幸的是,WL忘记跟他说是什么意思了。这个时候,ZYJ不得不求助与伟大的ZP。ZP笑了笑说,这个非常奇妙的,WL的意思是仅仅要你找到她给你的字符串在那个奇妙的字符串的位置,你就会有奇妙的发现。ZYJ恍然大悟,原来如此。可是悲剧来了,他居然不知道怎么找。
。。。是的。非常囧是不是。
所以这时候就须要化身为超级玛丽亚的你现身了,告诉他吧。
。
。
。。
。
输入
首先输入一个n。
表示有n组測试数据。
每组測试数据有两行。
第一行为字符串S1。长度不大于1000000。
第二行为字符串S2,长度不大于10000,而且长度不小于2。
输出
输出S2在S1的位置。
假设有多个位置,仅仅输出第一个位置。
假设找不到。就输出“::>_<::“(不输出双引號)。
演示样例输入
1 ASDFGDF DF
演示样例输出
3
///由于字符串长度不是非常大。能够直接用字符串匹配的方法不会超时,所以方法有两种
方法一:
#include<stdio.h>
#include<string.h>
#define N 1000001
char s1[N],s2[10010];
int main()
{
int n;
scanf("%d",&n);
getchar();
while(n--)
{
gets(s1);
gets(s2);
char *s3=strstr(s1,s2);
if(s3==NULL)
{
printf("::>_<::\n");
}
else
{
int k=s3-s1+1;
printf("%d\n",k);
}
}
return 0;
}
方法二:KMP算法
#include<stdio.h>
#include<string.h>
#define N 1000001
char s1[N],s2[10001];
int next[N];
void getnext()
{
int i=0,j=-1;
next[0]=-1;
while(s2[i]!='\0')
{
if(j==-1 || s2[i]==s2[j])
{
i++;
j++;
next[i]=j;
}
else
j=next[j];
}
}
void KMP()
{
int i=0,j=0;
getnext();
int len1=strlen(s1);
int len2=strlen(s2);
while(i<len1 && j<len2)
{
if(j==-1 || s1[i]==s2[j])
{
i++;
j++;
}
else
j=next[j];
}
if(j>=len2)
{
printf("%d\n",i-len2+1);
}
else
{
printf("::>_<::\n");
}
}
int main()
{
int n;
scanf("%d",&n);
getchar();
while(n--)
{
gets(s1);
gets(s2);
KMP();
}
return 0;
}