题目描述

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

现在,请你编程实现这一功能,具体要求是:给定一个单词,请你输出它在给定的文章中出现的次数和第一次出现的位置。注意:匹配单词时,不区分大小写,但要求完全匹配,即给定单词必须与文章中的某一独立单词在不区分大小写的情况下完全相同(参见样例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. C# 泛型中的数据类型判定与转换

    提到类型转换,首先要明确C#中的数据类型,主要分为值类型和引用类型: 1.常用的值类型有:(struct) 整型家族:int,byte,char,short,long等等一系列 浮点家族:float, ...

  2. Disease Manangement 疾病管理

    题目描述 Alas! \(A\) set of \(D (1 <= D <= 15)\) diseases (numbered \(1..D\)) is rshning through t ...

  3. 用Python把20年的GDP、人口以及房价数据进行了可视化

    前言 本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理. 作者:CDA数据分析师 提到一线城市,大家马上会想到北上广深这四个超级大都 ...

  4. 小白入门python新手教程python

    python教程很多,但是需要自学教程更好一些,看自学python教程3遍,然后一步步操作,7天后就会有很大的收货. 要向数据处理方向走,数据处理需要网络爬虫的知识,且更加精进.下面是我从网上查找这方 ...

  5. laravel 上线部署最佳实践

    nginx  配置 listen 80 default_server; server_name xxxx; index index.php index.html;    优先 index.php ro ...

  6. jupyter的服务器配置安装

    该教程主要针对的是服务器安装,且在后台保持稳定运行的情况. 1.jupyter下载 有网的时候 1. pip install jupyter 离线安装 在有网络的环境下载安装包 2. pip down ...

  7. 你不知道的JavaScript 上卷 2/11

    第一部分——作用域和闭包 第一章 作用域是什么 1.几乎所有编程语言最基本的功能之一,就是能够储存变量当中的值,并且能在之后对这个值进行访问或修改.事实上,正是这种储存和访问变量的值的能力将状态带给了 ...

  8. math库常用函数

  9. Python列表脚本操作符

    Python列表脚本操作符: len(列表名): 查看列表长度 # 使用 len(列表名) 方法查看列表长度 lst = [1,2,3,4] print(len(lst)) # # 注:嵌套列表算一个 ...

  10. SQL Server 枚举异或运算后值存入数据库,读取符合条件的值

    有枚举如下: [Flags] public enum Color { Red = , Green = , Blue = , White = } 定义三个枚举变量,并将值存入数据库: Color col ...