【洛谷 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;
}
相关推荐
jdlxx_dongfangxing1 小时前
C++ 序列式容器深度解析:vector、string、deque 与 list
c++·stl
月盈缺1 小时前
学习嵌入式的第二十四天——数据结构——队列和树
数据结构·学习
欧阳小猜2 小时前
深度学习②【优化算法(重点!)、数据获取与模型训练全解析】
人工智能·深度学习·算法
小欣加油2 小时前
leetcode 904 水果成篮
c++·算法·leetcode
有Li2 小时前
CXR-LT 2024:一场关于基于胸部X线的长尾、多标签和零样本疾病分类的MICCAI挑战赛|文献速递-深度学习人工智能医疗图像
论文阅读·人工智能·算法·医学生
君万2 小时前
【LeetCode每日一题】56. 合并区间
算法·leetcode·golang
墩墩同学2 小时前
【LeetCode题解】LeetCode 287. 寻找重复数
算法·leetcode·二分查找
小南家的青蛙3 小时前
LeetCode第55题 - 跳跃游戏
算法·leetcode·职场和发展
Tipriest_3 小时前
C++ csignal库详细使用介绍
开发语言·c++·csignal·信号与异常
qq_25929724733 小时前
QT-窗口类部件
c++·qt