学password学一定得学程序
题目描写叙述
以前。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;
}
学password学一定得学程序的更多相关文章
- 我是该学JAVA呢,还是学IOS开发呢?
摘要: iOS就像Andriod一样,不是编程语言,而是操作系统.学iOS开发,其实学的是如何用Objective-C在苹果操作系统上进行各种应用程序的开发.就像学Andriod开发,其实是学如何用J ...
- 我是先学C语言还是先学C++,实不相瞒,鱼和熊掌可兼得!
这是最近一周时间几个读者小伙伴所提的问题,我顺手截了两个图. 实不相瞒,这类问题之前也经常看到. 每次遇到这种问题,看起来很简单,但是打字一时半会还真说不清,想想今天周末了,写一篇文章来统一聊 ...
- python入门灵魂5问--python学习路线,python教程,python学哪些,python怎么学,python学到什么程度
一.python入门简介 对于刚接触python编程或者想学习python自动化的人来说,基本都会有以下python入门灵魂5问--python学习路线,python教程,python学哪些,pyth ...
- 学习用CMake来编写Qt程序
最近开始学习CMake,因为项目需求需要用到Qt,自带的qmake会出现许多问题(比如文件修改之后有时候qmake不会侦测到不会重新编译,需要手动去编译等),于是开始尝试使用CMake来编写Qt程序, ...
- 菜鸟学Linux命令:nohup命令启动程序
在UNIX/LINUX中,普通进程用&符号放到后台运行,如果启动该程序的控制台logout,则该进程随即终止. 要实现守护进程,一种方法是按守护进程的规则去编程,比较麻烦:另一种方法是仍然用普 ...
- 跟我一起学WCF(4)——第一个WCF程序
一.引言 前面几篇文章分享了.NET 平台下其他几种分布式技术,然而前面几种分布式技术专注于某一特定的领域,并且具有不同编程接口,这使得开发人员需要掌握多个API的使用.基于这样的原因,微软在.NET ...
- 动手学servlet(一) 第一个servlet程序
1.文件>新建>动态WEB项目 "javaeedemo">在Java Resource的src下新建包“servletdemo”,包下新建一个类“MyServet ...
- 一起学android之怎样获取手机程序列表以及程序相关信息并启动指定程序 (26)
效果图: 程序列表: watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvaGFpX3FpbmdfeHVfa29uZw==/font/5a6L5L2T/fonts ...
- 《OD学微信开发》微信小程序入门示例
官网地址: https://mp.weixin.qq.com/debug/wxadoc/dev/ 一.文件结构 小程序包含一个描述整体程序的 app 和多个描述各自页面的 page. .js后缀的是脚 ...
随机推荐
- 爬虫来啦!Day91
# 一.爬虫# 1.基本操作# 排名爬虫刷票# 抽屉网的所有发布新闻点赞# 自动化程序模拟用于的日常操作# 投票的机制是利用cookies,禁用cookies模式# 自定义的异步IO模块就是Socke ...
- 正则效验url
上篇文章讲到多主题的解决方案:简单暴力的TP5多主题方案 为了简化配置,所以将域名前的协议 http/https 截取了. 后台配置时就需要效验配置的格式是否正确,需要用到的正则代码如下: /*** ...
- 带入gRPC:gRPC Deadlines
带入gRPC:gRPC Deadlines 原文地址:带入gRPC:gRPC Deadlines项目地址:https://github.com/EDDYCJY/go... 前言 在前面的章节中,已经介 ...
- [luogu] P2787 语文1(chin1)- 理理思维(分块)
P2787 语文1(chin1)- 理理思维 题目背景 蒟蒻HansBug在语文考场上,挠了无数次的头,可脑子里还是一片空白. 题目描述 考试开始了,可是蒟蒻HansBug脑中还是一片空白.哦不!准确 ...
- Unity Microphone 无限时长录制
原创文章:转载请标明出处--博客园 Jason_c Unity可以很方便的通过 Microphone.Start()方法来调用麦克风,但是有一个弊端是,必须传入时长,这就很尴尬了,因为大多数时间,我们 ...
- Java Bean 简单介绍及其应用
Bean的中文含义是"豆子",顾名思义JavaBean是一段Java小程序.JavaBean实际上是指一种特殊的Java类.它通经常使用来实现一些比較经常使用的简单功能.并能够非常 ...
- 【数据压缩】JPEG标准与原理解析
转载请注明出处:http://blog.csdn.net/luoshixian099/article/details/50392230 CSDN-勿在浮沙筑高台 为了满足不同应用的需求,JPEG标准包 ...
- android客户端向java服务端post发送json
android 端: private void HttpPostData() { try { HttpClient httpclient = new DefaultHttpClient( ...
- Swift学习笔记(3):基本运算符
目录: 运算符 元组比较 空和运算符 区间运算符 运算符 +, -, *, /, %, =, +=, -=, *=, /= 算术运算符 >, <, ==, >=, <=, != ...
- python2中打印列表与字典内的中文字符
在开发过程中,我们经常需要打印一些变量的值,便于调试.这个时候就会发现如果在列表与字典这些容器中,如果包含中文字符,不管是str类型,还是unicode类型,都打印不出来.如下: >>&g ...