题目描述

一般的文本编辑器都有查找单词的功能,该功能可以快速定位特定单词在文章中的位置,有的还能统计出特定单词在文章中出现的次数。

现在,请你编程实现这一功能,具体要求是:给定一个单词,请你输出它在给定的文章中出现的次数和第一次出现的位置。注意:匹配单词时,不区分大小写,但要求完全匹配,即给定单词必须与文章中的某一独立单词在不区分大小写的情况下完全相同(参见样例1),如果给定单词仅是文章中某一单词的一部分则不算匹配(参见样例2 )。

输入格式

共2行。

第1行为一个字符串,其中只含字母,表示给定单词;

第2行为一个字符串,其中只可能包含字母和空格,表示给定的文章。

输出格式

一行,如果在文章中找到给定单词则输出两个整数,两个整数之间用一个空格隔开,分别是单词在文章中出现的次数和第一次出现的位置(即在文章中第一次出现时,单词首字母在文章中的位置,位置从0开始);如果单词在文章中没有出现,则直接输出一个整数−1。

输入输出样例

输入 #1

To

to be or not to be is a question

输出 #1

2 0

输入 #2

to

Did the Ottoman Empire lose its power at that time

输出 #2

-1


我的分析

乍一看,该题目比传统字符串模式匹配简单。因为单词已经用空格分开,一个单词初始部分匹配不成功就不需要看该单词剩余部分了,直接跳到下一个单词即可。算法中更不存在传统模式匹配中游标i在匹配不成功后还要退回去重新匹配的尴尬处境,全程遍历游标i只需要向右移动而无须回退。我们最终可以轻易地写出时间复杂度为O(n)的算法,n为英文文章的长度。

 

 

然而,第一次提交代码时我居然有部分case没有过!诶?



我眉头微微一皱,发现想要写出对所有case都AC的健壮代码,事情并没有那么简单。。。╮(╯◇╰)╭

 

如何读取带有空格的字符串?是否可考虑了边界问题?比如处理最后一个单词时数组下标会不会越界?是否周全考虑了模式串长于或短于某单词的情况?是否全面考虑了模式串出现在某单词开头,中间,末尾的情况,以保证你的算法不会出现错判?以上个个都是坑,稍不注意就会掉进坑里,更恐怖的掉进坑里了你还浑然不觉。

 

说实话,这道题的算法我修修补补,各种断点调试了半天,始终有问题。最后我采取了一个小技巧,就是在原来的单词文章后面再加一个空格,这对于后面防止数组越界和简化一些条件判断都非常有帮助,大大简化了代码。

 

我最终提交并AC的代码如下:

#include<iostream>
using namespace std;
int main(){
string p;
string s;
getline(cin,p); //读取一行字符串(包括空格)
getline(cin,s);
int pos=-1;
int count=0;
s +=' ';
for(int i=0;i<s.length();++i){
//单词和模式串的首字母相同(不分大小写)即开始匹配
if(s[i]==p[0]||abs(s[i]-p[0])==32){ 
int tmp=i; //记录开始匹配时i的位置
bool flag=1;//标志flag为表示匹配是否成功
for(int j=1;j<p.length();++j){
i++;
if(s[i]!=p[j]&&abs(s[i]-p[j])!=32){
flag=0;
break;
}
}
//就算全部匹配,还必须保证除了模式串,
//单词后面是空格而非其他字母,否则不匹配
if(flag==1){
if(s[i+1]!=' '){
flag=0;
}
}
//满足匹配要求,计数加一
//若是第一次匹配成功,记录本次开始匹配的位置
if(flag){
count++;
if(pos==-1) pos=tmp;
}
//跳到下一个单词,保证不在本单词继续匹配了
while(s[i]!=' ') i++;
}
//否则,直接跳到下一个单词
else{
while(s[i]!=' ') i++;
}
}
if(count==0) cout<<"-1"<<endl;
if(count>0) cout<<count<<" "<<pos<<endl;
return 0;
}

洛谷P1308.统计单词数(字符串匹配)的更多相关文章

  1. 洛谷 P1308 统计单词数【字符串+模拟】

    P1308 统计单词数 题目描述 一般的文本编辑器都有查找单词的功能,该功能可以快速定位特定单词在文章中的位置,有的还能统计出特定单词在文章中出现的次数. 现在,请你编程实现这一功能,具体要求是:给定 ...

  2. 洛谷 P1308 统计单词数【字符串处理】

    题目描述 一般的文本编辑器都有查找单词的功能,该功能可以快速定位特定单词在文章中的位置,有的还能统计出特定单词在文章中出现的次数. 现在,请你编程实现这一功能,具体要求是:给定一个单词,请你输出它在给 ...

  3. 洛谷 P1308 统计单词数

    P1308 统计单词数 题目描述 一般的文本编辑器都有查找单词的功能,该功能可以快速定位特定单词在文章中的位置,有的还能统计出特定单词在文章中出现的次数. 现在,请你编程实现这一功能,具体要求是:给定 ...

  4. 洛谷 P1026 统计单词个数

    题目描述 给出一个长度不超过200的由小写英文字母组成的字母串(约定;该字串以每行20个字母的方式输入,且保证每行一定为20个).要求将此字母串分成k份(1<k<=40),且每份中包含的单 ...

  5. 【洛谷】P1308 统计单词数-全AC题解(易理解

    弟弟的混乱代码(易理解 大概 思路: 循环b(被找的字符串),遇空格比较两空格间的长度是否与a(需要查找的字符)相等:不相等继续循环:相等比较内容是否相同(倒数比较,不一样直接退出 ,直到比较到第一个 ...

  6. 洛谷 P1026 统计单词个数 Label:dp

    题目描述 给出一个长度不超过200的由小写英文字母组成的字母串(约定;该字串以每行20个字母的方式输入,且保证每行一定为20个).要求将此字母串分成k份(1<k<=40),且每份中包含的单 ...

  7. [NOIP2001] 提高组 洛谷P1026 统计单词个数

    题目描述 给出一个长度不超过200的由小写英文字母组成的字母串(约定;该字串以每行20个字母的方式输入,且保 证每行一定为20个).要求将此字母串分成k份(1<k<=40),且每份中包含的 ...

  8. 洛谷P1026 统计单词个数【区间dp】

    题目:https://www.luogu.org/problemnew/show/P1026 题意: 给定一个字符串,要求把他分成k段.给定s个单词,问划分成k段之后每段中包含的单词和最大是多少. 一 ...

  9. 洛谷 P1308 统计单词数【string类及其函数应用/STL】

    题目描述 一般的文本编辑器都有查找单词的功能,该功能可以快速定位特定单词在文章中的位置,有的还能统计出特定单词在文章中出现的次数. 现在,请你编程实现这一功能,具体要求是:给定一个单词,请你输出它在给 ...

随机推荐

  1. JQuery如何在验证表单失败的情况下阻止表单提交

    自定义验证时,使用了return false和event.preventDefault(),但是验证失败之后表单还是提交了 这个问题我也碰到了,尝试了多次也没有用,在调试的时候也发现确实return了 ...

  2. iOS打包测试ipa

    1. 连接iphone真机 2.选中真机, archive

  3. SpringSecurity+Oauth2+Jwt实现toekn认证和刷新token

    简单描述:最近在处理鉴权这一块的东西,需求就是用户登录需要获取token,然后携带token访问接口,token认证成功接口才能返回正确的数据,如果访问接口时候token过期,就采用刷新token刷新 ...

  4. SQL查询基本用法

    -- 单列查询 select 编号 from employees -- 多列查询 select 编号,姓名 from employees -- 查询所有列 select * from employee ...

  5. element上传功能携带参数

    在写element的上传功能时,需要对上传的文件携带参数,但是参数比较多,就需要一个对象合并的方法,Object.assign() Object.assign(target, source1, sou ...

  6. 【NeurlPS2019】Positional Normalization 位置归一化

    作者提出,当前的BatchNorm, GroupNorm, InstanceNorm在空间层面归一化信息,同时丢弃了统计值.作者认为这些统计信息中包含重要的信息,如果有效利用,可以提高GAN和分类网络 ...

  7. ES数据库重建索引——Reindex(数据迁移)

    应用背景: 1.当你的数据量过大,而你的索引最初创建的分片数量不足,导致数据入库较慢的情况,此时需要扩大分片的数量,此时可以尝试使用Reindex. 2.当数据的mapping需要修改,但是大量的数据 ...

  8. 萌新学渗透系列之Hack The Box_Devel

    我将我的walkthrough过程用视频解说的形式记载 视频地址https://www.bilibili.com/video/BV1Ck4y1B7DB 一是因为看我视频的后来者应该都是刚入门的新手,视 ...

  9. PHP入门之函数

    前言 之前对PHP的类型.运算符和流程控制简单说了一下.想了解的,这是地址. PHP入门之类型与运算符 PHP入门之流程控制 下面对函数简单说一下. 函数的基本概念 为完成某一个功能的程序指令的合集, ...

  10. PHP array_pop() 函数

    实例 删除数组中的最后一个元素: <?php$a=array("red","green","blue");array_pop($a); ...