【洛谷 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;
}
相关推荐
算法_小学生几秒前
LeetCode 287. 寻找重复数(不修改数组 + O(1) 空间)
数据结构·算法·leetcode
岁忧几秒前
(LeetCode 每日一题) 1865. 找出和为指定值的下标对 (哈希表)
java·c++·算法·leetcode·go·散列表
alphaTao1 分钟前
LeetCode 每日一题 2025/6/30-2025/7/6
算法·leetcode·职场和发展
ゞ 正在缓冲99%…1 分钟前
leetcode67.二进制求和
算法·leetcode·位运算
YuTaoShao4 分钟前
【LeetCode 热题 100】240. 搜索二维矩阵 II——排除法
java·算法·leetcode
whoarethenext16 分钟前
使用 C++ 实现 MFCC 特征提取与说话人识别系统
开发语言·c++·语音识别·mfcc
R-G-B16 分钟前
【MFC】Combobox下拉框中4个选项,运行后点击下拉框选项不能全部展示出来,只能显示2个选项,需要垂直滚动条滚动显示其余选项
c++·mfc
写个博客1 小时前
暑假算法日记第二天
算法
ChaITSimpleLove1 小时前
.NET9 实现排序算法(MergeSortTest 和 QuickSortTest)性能测试
算法·排序算法·.net·benchmarkdotnet·datadog.trace
CVer儿1 小时前
svd分解求旋转平移矩阵
线性代数·算法·矩阵