【洛谷 P1308】[NOIP2011 普及组] 统计单词数 题解(字符串+字符串流)

[NOIP2011 普及组] 统计单词数

题目描述

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

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

输入格式

共 2 2 2 行。

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

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

输出格式

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

样例 #1

样例输入 #1

复制代码
To
to be or not to be is a question

样例输出 #1

复制代码
2 0

样例 #2

样例输入 #2

复制代码
to
Did the Ottoman Empire lose its power at that time

样例输出 #2

复制代码
-1

提示

数据范围

1\\leq 第一行单词长度 ≤ 10 \leq10 ≤10。

1\\leq 文章长度 ≤ 1 0 6 \leq10^6 ≤106。

noip2011 普及组第 2 题


思路

代码首先使用 cin 获取输入的单词和一行文本。为了忽略大小写,将单词和文本统一转换为小写字母形式。

创建一个 stringstream 对象 ss 并将文本字符串传递给它。使用 ss >> w 循环读取 ss 中的每个单词。使用 w.compare(word) 比较当前单词和输入的单词是否相同。如果相同,则增加 cnt 的值,并检查是否为第一次出现。

定义两个字符串 word_line_,分别是在单词和文本两端添加空格的结果,以确保只匹配完整的单词。如果是第一次出现,则使用 line_.find(word_) 找到第一次出现的位置。

如果单词出现次数大于0,则输出次数和第一次出现的位置。如果单词没有出现,则输出 -1


AC代码

cpp 复制代码
#include <iostream>
#include <string>
#include <cstring>
#include <algorithm>
#include <sstream>
#define AUTHOR "HEX9CF"
using namespace std;

string word, word_;
string line, line_;
stringstream ss;

int main()
{
    cin >> word;
    getchar();
    getline(cin, line);

    // 全部转换成小写字母
    transform(word.begin(), word.end(), word.begin(), ::tolower);
    transform(line.begin(), line.end(), line.begin(), ::tolower);

    ss.str(line);

    word_ = ' ' + word + ' ';
    line_ = ' ' + line + ' ';

    int cnt = 0;
    int firstPos = 0;

    for(string w; ss >> w; ) {
        if(!w.compare(word)) {
            if(!cnt) {
                firstPos = line_.find(word_);
            }
            cnt++;
        }
    }

    if (cnt)
    {
        cout << cnt << " " << firstPos << endl;
    }
    else
    {
        cout << ~0 << endl;
    }

    return 0;
}
相关推荐
海码0074 分钟前
【Hot 100】94. 二叉树的中序遍历
数据结构·c++·算法·二叉树·hot100
CodeWithMe11 分钟前
【C/C++】Linux的futex锁
linux·c语言·c++
Light6027 分钟前
探秘数据结构:构建高效算法的灵魂密码
数据结构·可视化·算法优化·性能分析·应用场景
Wabi_sabi_x1 小时前
C++设计模式:面向对象的八大设计原则之二
开发语言·c++·设计模式
一道秘制的小菜1 小时前
AimRT从入门到精通 - 04RPC客户端和服务器
linux·运维·服务器·c++·aimrt
虾球xz1 小时前
游戏引擎学习第256天:XBox 控制器卡顿和修复 GL Blit 伽玛问题
c++·学习·游戏引擎·xbox
zhangpeng4555479401 小时前
数据结构-线性结构(链表、栈、队列)实现
数据结构·链表
꧁坚持很酷꧂2 小时前
C++的基础知识(引用、类、封装、继承、多态、函数重载)
开发语言·c++
mahuifa2 小时前
(37)VTK C++开发示例 ---纹理地球
c++·vscode·vtk·3d地球
躺不平的理查德3 小时前
C++-Lambda表达式
开发语言·c++