【洛谷 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;
}
相关推荐
无名之逆6 分钟前
lombok-macros
开发语言·windows·后端·算法·面试·rust·大学期末
yuanbenshidiaos10 分钟前
C++-----图
开发语言·c++·算法
就一枚小白13 分钟前
UE--如何用 Python 调用 C++ 及蓝图函数
c++·python·ue5
逊嘘25 分钟前
【Java数据结构】链表相关的算法
java·数据结构·链表
爱编程的小新☆26 分钟前
不良人系列-复兴数据结构(二叉树)
java·数据结构·学习·二叉树
✿ ༺ ོIT技术༻33 分钟前
同步&异步日志系统:设计模式
linux·c++·设计模式
忘梓.40 分钟前
解锁动态规划的奥秘:从零到精通的创新思维解析(4)
算法·动态规划
戊辰happy5 小时前
arcface
算法
浊酒南街6 小时前
决策树python实现代码1
python·算法·决策树
獨枭7 小时前
CMake 构建项目并整理头文件和库文件
c++·github·cmake