题目描写叙述

以前。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;
}

最新文章

  1. 最新Sublime Text 2 激活 汉化
  2. wp插件
  3. Linux Discuz论坛的安装
  4. Qt resizeEvent 控件居中设置
  5. 【iCore2 模块相关资料】发布模块DEMO 代码包,目前支持 iM_TFT30、 iM_LAN和 iM_RGB 三个模块
  6. 使用原生js写ajax
  7. WEBrick/Rack Puppet Master
  8. 介绍几个移动web app开发框架
  9. 多线程:pthread_exit,pthread_join,pthread_self
  10. mockplus 原型设计工具
  11. CentOS 7 (Linux) 下载百度网盘大文件
  12. vue:资源小记
  13. python------Socket网络编程(二)粘包问题
  14. 修改idea自动生成在C盘的文件路径,以免电脑越用越卡
  15. asp.net mvc 笔记一
  16. &lt;mvc:annotation-driven/&gt;的作用
  17. Mysql覆盖索引与延迟关联
  18. 警告: Hessian/Burlap: &#39;com.github.pagehelper.Page&#39; is an unknown class in WebappClassLoader
  19. Windows Server 2008系统中IE8启用和禁用JS
  20. js为什么放到head中有时候失效

热门文章

  1. 关于iptables允许samba的问题
  2. 紫书 例题 11-14 UVa 1279 (动点最小生成树)(详细解释)
  3. NPOI操作Excel 004:写入空Excel(添加保存提示框)
  4. HDU 5310 Souvenir
  5. Caffe-python interface 学习|网络训练、部署、測试
  6. hdu4089Activation 概率dp
  7. programming-challenges Shoemaker&amp;#39;s Problem (110405) 题解
  8. excle查找操作-vlookup的使用心得
  9. spark scala word2vec 和多层分类感知器在情感分析中的实际应用
  10. Java类和对象6