题目描述

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

现在,请你编程实现这一功能,具体要求是:给定一个单词,请你输出它在给定的文章中出现的次数和第一次出现的位置。注意:匹配单词时,不区分大小写,但要求完全匹配,即给定单词必须与文章

中的某一独立单词在不区分大小写的情况下完全相同(参见样例1 ),如果给定单词仅是文章中某一单词的一部分则不算匹配(参见样例2 )。

输入输出格式

输入格式:

共 22 行。

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

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

输出格式:

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

说明

数据范围

1≤1≤ 单词长度 ≤10≤10 。

1≤1≤ 文章长度 ≤1,000,000≤1,000,000 。

noip2011普及组第2题

需要注意的点:

1.tolower()和toupper()只会返回一个转化了大小写的值,而不会错误,并不会改变原数组的值,所以不能用来直接改变数组的大小写。

2.transform(s1.begin(), s1.end(),s1.begin(), ::tolower);可以把整个字符串变成小写的。

3.getline前如果有cin输入,需要在前面加getchar()或者cin.ignore()读入或丢弃之前在缓冲区留下的换行符.

 #include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
using namespace std;
int main()
{
string s1;
char s2[];
cin >> s1;
transform(s1.begin(), s1.end(),s1.begin(), ::tolower);//把s1全转化为小写
getchar();
cin.getline(s2,sizeof(s2)/sizeof(s2[]));
int index = ,cnt = ;
int s = ,e = ;
int find = -;
//0123456789
//*to*d**to
while(s2[s]!='\0' && s2[e]!='\0')
{
s = e;
while(s2[s]==' '&& s2[s]!='\0')
{
s++;
}
e = s;
while(s2[e]!=' ' && s2[e]!='\0')
{
e++;
}
//从s到e-1全转化为小写
if(s1.size()==(e-s))
{
bool flag = true;
for(int i = ;i<e-s;++i)
{
if(isupper(s2[s+i]))//s2[s+i]<'a'
{
s2[s+i] += ;//lower(s2[s+i]);错误,并不会改变原数组的值
}
if(s1[i] != s2[s+i])
{
flag = false;
break;
}
}
if(flag == true)
{
if(find==-)
{
find = s;
}
cnt++;
}
}
}
if(cnt == )
{
cout << - << endl;
}
else
{
cout << cnt<<" "<<find << endl;
}
return ;
}

最新文章

  1. Call for Papers International Conference for Smart Health (ICSH) 2014
  2. 1118sync_binlog innodb_flush_log_at_trx_commit 浅析
  3. List&lt;List&lt;String&gt;&gt;
  4. 定时器图片轮播淡入淡出基本功能已实现,正在修改BUG中。。(附图效果和源代码)
  5. [转]iptables详解
  6. 跟着百度学PHP[1]-if条件嵌套
  7. chmod u+x ./j2sdk-1_4_2_04-linux-i586.bin的含义
  8. Java通过JDBC连接Oracle之后查询结果和在sqlplus查询结果不一样
  9. 页面d初始化加载
  10. python time模块函数
  11. 如何使用Prism框架的EventAggregator在模块间进行通信
  12. 检查java class的版本号
  13. [转载]解决sudo: sorry, you must have a tty to run sudo
  14. 走进netty
  15. 【翻译】Flume 1.8.0 User Guide(用户指南) Processors
  16. 来自后端的突袭? --开包即食的教程带你浅尝最新开源的C# Web引擎 Blazor
  17. 048 SparkSQL自定义UDAF函数
  18. DockerSwarm+Dubbo镜像与部署相关命令与参数
  19. linux-Centos7安装python3并与python2共存
  20. 【转】OAuth的改变

热门文章

  1. c++ 编译器会绕过拷贝构造函数
  2. Script Library 配置 和 使用
  3. tiny4412 裸机程序 七、重定位代码到DRAM【转】
  4. luogu 3808 【模板】AC自动机(简单版)
  5. JSP-Runoob:JSP 点击量统计
  6. MySQL 1366错误解决办法
  7. Django总结二
  8. PHP富文本编辑器 之Kindeditor的使用 一
  9. Hadoop Hive概念学习系列之hive里的视图(十二)
  10. scala控制流程语句