学password学一定得学程序
2024-08-30 08:08:01
题目描写叙述
以前。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;
}
最新文章
- 最新Sublime Text 2 激活 汉化
- wp插件
- Linux Discuz论坛的安装
- Qt resizeEvent 控件居中设置
- 【iCore2 模块相关资料】发布模块DEMO 代码包,目前支持 iM_TFT30、 iM_LAN和 iM_RGB 三个模块
- 使用原生js写ajax
- WEBrick/Rack Puppet Master
- 介绍几个移动web app开发框架
- 多线程:pthread_exit,pthread_join,pthread_self
- mockplus 原型设计工具
- CentOS 7 (Linux) 下载百度网盘大文件
- vue:资源小记
- python------Socket网络编程(二)粘包问题
- 修改idea自动生成在C盘的文件路径,以免电脑越用越卡
- asp.net mvc 笔记一
- <;mvc:annotation-driven/>;的作用
- Mysql覆盖索引与延迟关联
- 警告: Hessian/Burlap: &#39;com.github.pagehelper.Page&#39; is an unknown class in WebappClassLoader
- Windows Server 2008系统中IE8启用和禁用JS
- js为什么放到head中有时候失效
热门文章
- 关于iptables允许samba的问题
- 紫书 例题 11-14 UVa 1279 (动点最小生成树)(详细解释)
- NPOI操作Excel 004:写入空Excel(添加保存提示框)
- HDU 5310 Souvenir
- Caffe-python interface 学习|网络训练、部署、測试
- hdu4089Activation 概率dp
- programming-challenges Shoemaker&;#39;s Problem (110405) 题解
- excle查找操作-vlookup的使用心得
- spark scala word2vec 和多层分类感知器在情感分析中的实际应用
- Java类和对象6