牛客练习赛51 B 子串查询 https://ac.nowcoder.com/acm/contest/1083/B
题目描述
输入描述:
第一行两个数n,q。1<=n,q<=1e5。 第二行一个长度为n的字符串s,所有字符都为小写拉丁字符。 接下来q行每行一个字符串t。1<=|t|<=50。
输出描述:
对于每个查询,如果t是s的字串,输出”YES”,否则输出”NO”。每个答案占一行。
输出
YES
NO
YES
YES ac代码:
方法一:
#include<bits/stdc++.h>using namespace std;int n,q,i,pos,f;string s,a;int main(){ cin>>n>>q>>s; while(q--){ cin>>a; pos=0; f=1; for(int i=0;i<a.length()&&f;i++){ auto it = s.find(a[i],pos); if(it==s.npos) f=0; else pos = it+1;//要查找下一个,所以+1 } if(f) cout<<"YES"<<endl; else cout<<"NO"<<endl; } return 0;}| 方法原型 | 描述 |
|---|---|
| size_type find(const string & str, size_type pos = 0) const | 从字符串的pos位置开始,查找子字符串str。如果找到,则返回该子字符串首次出现时其首字符的索引;否则,返回string::npos |
| size_type find(const char * s, size_type pos = 0) const | 从字符串的pos位置开始,查找子字符串s。如果找到,则返回该子字符串首次出现时其首字符的索引;否则,返回string::npos |
| size_type find(const char * s, size_type pos = 0, size_type n) const | 从字符串的pos位置开始,查找s的前n个字符组成的子字符串。如果找到,则返回该子字符串首次出现时其首字符的索引;否则,返回string::npos |
| size_type find(const char ch, size_type pos = 0) const | 从字符串的pos位置开始,查找字符ch。如果找到,则返回该子字符串首次出现的位置;否则,返回string::npos |
#include<bits/stdc++.h>
using namespace std;
int N,Q,a[30],n[30],b[100005][30];
string s;
int main(){
cin>>N>>Q;
cin>>s;
int len = s.length();
memset(n,-1,sizeof(n));
for(int i = len-1;i>=0;i--){
int x = s[i]-'a';//相当于把字符转换为数字a就是0,b就是1,以此类推
for(int j=0;j<26;j++){
b[i][j] = n[j];
}
n[x] = i;
}
for(int i=1;i<=Q;i++){
string q;
cin>>q;
int cg = q.size();//这里我用q.length()就会超时;
int iq = 0,is,cnt = 0;
while(iq<len&&cnt<cg){
if(cnt==0) iq = n[q[0]-'a'];
else{
if(b[iq][q[cnt]-'a']!=-1)
iq = b[iq][q[cnt]-'a'];
else
break;
}
cnt++;
}
if(cnt == cg) cout<<"YES"<<endl;
else cout<<"NO"<<endl;
}
return 0;
}
a b a b c b a a
a b a c
b[7][0 - 25]= -1; n[0]=7;
b[6][0] = 7;b[6][1-25]=-1; n[0]=6;
b[5][0]=6,b[5][1-25]=-1; n[1] = 5;
b[4][0]=6,b[4][1]=5,b[4][2-25]=-1; n[2] = 4;
//当遍历到c时,b[4][0]记录的是最先的a(0代表a)的位置,b[4][1]记录的是最先的b的位置
...
i从后往前是为了统计当从这个字母开始(不包括这个字母)后面的字母的位置,n中0就代表a,1就代表b,
然后这样就可以统计记录整个表的情况,如果是i从前遍历就不能做到
下面判断当cnt==0时要单独拿出来,就是因为当遍历到这个字母时,统计是不包括这个字母的。
b有len层,相当于在跳层的验证是否这个位置是存了数的,如果是-1就相当于没有这个数,就跳出循环输出NO。
牛客练习赛51 B 子串查询 https://ac.nowcoder.com/acm/contest/1083/B的更多相关文章
- 牛客练习赛51 C 勾股定理https://ac.nowcoder.com/acm/contest/1083/C
题目描述 给出直角三角形其中一条边的长度n,你的任务是构造剩下的两条边,使这三条边能构成一个直角三角形. 输入描述: 一个整数n. 输出描述: 另外两条边b,c.答案不唯一,只要输出任意一组即为合理, ...
- 牛客练习赛51 **E-数列** (二分,贪心,构造)
牛客练习赛51 E-数列 链接:https://ac.nowcoder.com/acm/contest/1083/E来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 327 ...
- 牛客练习赛51 D题
链接:https://ac.nowcoder.com/acm/contest/1083/D来源:牛客网 有一个草原可以用一个1~400的数轴表示.有n头羊和q个查询.每头羊的编号分别是1,2,3…n. ...
- 牛客练习赛51 C 勾股定理 (数学,结论)
链接:https://ac.nowcoder.com/acm/contest/1083/C来源:牛客网 题目描述 给出直角三角形其中一条边的长度n,你的任务是构造剩下的两条边,使这三条边能构成一个直角 ...
- 牛客练习赛51 C 勾股定理
链接:https://ac.nowcoder.com/acm/contest/1083/C 题目描述 给出直角三角形其中一条边的长度n,你的任务是构造剩下的两条边,使这三条边能构成一个直角三角形. 输 ...
- 牛客-https://www.nowcoder.com/acm/contest/96/H
链接:https://www.nowcoder.com/acm/contest/96/H来源:牛客网 题目描述 今天qwb要参加一个数学考试,这套试卷一共有n道题,每道题qwb能获得的分数为ai,qw ...
- 牛客练习赛51 A abc
A. abc 题意: 给出一个字符串s,你需要做的是统计s中子串”abc”的个数.子串的定义就是存在任意下标a<b<c,那么”s[a]s[b]s[c]”就构成s的一个子串.如”abc”的子 ...
- 牛客练习赛52 B题【树状数组维护区间和{查询区间和,如果区间元素重复出现则计数一次}】补题ing
[题目] 查询区间和,如果区间元素重复出现则计数一次. 链接:https://ac.nowcoder.com/acm/contest/1084/B [题解] 将询问按r排序,维护每个数最后出现的位置, ...
- 牛客练习赛33 E tokitsukaze and Similar String (字符串哈希hash)
链接:https://ac.nowcoder.com/acm/contest/308/E 来源:牛客网 tokitsukaze and Similar String 时间限制:C/C++ 2秒,其他语 ...
随机推荐
- 遵循PEP8风格指南
整理来自 effective python 一 空白 1 使用space来标识缩进,而不是tab 2 和语法相关的每层缩进都使用4个空格 3 每行的字符数不应该超过79 4 对于多行的表达式,除了首行 ...
- 9.Jmeter自定义Sample(自定义测试内容)完成测试
问题:在某些场景下我们会发现Jmeter里面提供的各种Sample不能满足自己的需求,应为这个世界上的压力测试的逻辑本来就是千变万化的,所以这个时候我们如果自己实现一套测试逻辑(当Jmeter的基本e ...
- python2和python3中int整型数据的不同之处
python2中的除法,结果为整型数字(int型),例如 10/5=2,10/3=3,小数位向下取整 python3中的除法,结果为浮点型数字(float型)结果小数位最多保留16位小数
- neo4j APOC与自定义存储过程环境搭建
neo4j APOC与自定义存储过程环境搭建 主要参考资料:APOC官网https://neo4j-contrib.github.io/neo4j-apoc-procedures/APOC介绍 PPT ...
- Android开发——回调(Callback)
1. 回调函数的定义: 在A类中定义了一个方法,这个方法中用到了一个接口和该接口中的抽象方法,但是抽象方法没有具体的实现,需要B类去实现,B类实现该方法后,它本身不会去调用该方法,而是传递给A类,供A ...
- MySQL索引与事务
MySQL索引与事务 链接:https://pan.baidu.com/s/1ANGg3Kd_28BzQrA5ya17fQ 提取码:ekpy 复制这段内容后打开百度网盘手机App,操作更方便哦 1.索 ...
- Java中实现线程通信的三个方法的作用是什么?
Java提供了3个方法解决线程之间的通信问题,均是java.lang.Object类的方法,都只能在同步方法或者同步代码块中使用,否则会抛出异常. 方法名 作 用 final void wait() ...
- spark算子之Aggregate
Aggregate函数 一.源码定义 /** * Aggregate the elements of each partition, and then the results for all the ...
- Tomcat免安装版踩坑
下载解压 从官网下载Tomcat的压缩包解压到硬盘上(这里用的是toncat7),解压之后目录如下(Windows) bin 存放tomcat的一些命令脚本 conf 存放配置文件 lib 存放运行时 ...
- 电子商务B2B的发展趋势
B2B的发展趋势 尽管B2B市场发展势头良好,但B2B市场还是存在发育不成熟的一面.这种不成熟表现在B2B交易的许多先天性交易优势,比如在线价格协商和在线协作等还没有充分发挥出来. 报告指出,到200 ...