【洛谷 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;
}
相关推荐
AI进化营-智能译站2 小时前
ROS2 C++开发系列17-多线程驱动多传感器|chrono高精度计时实现机器人同步控制
java·c++·ai·机器人
一切皆是因缘际会5 小时前
从概率拟合到内生心智:2026 下一代 AI 架构演进与落地实践
人工智能·深度学习·算法·架构
墨染千千秋5 小时前
C++函数的使用以及主函数
c++
Java成神之路-5 小时前
【LeetCode 刷题笔记】34. 在排序数组中查找元素的第一个和最后一个位置 | 二分查找经典刷题题解
算法·leetcode
不忘不弃5 小时前
用BFS方法求解平分汽油问题
算法·宽度优先
AI科技星5 小时前
全域数学·72分册·射影原本 无穷维射影几何卷细化子目录【乖乖数学】
人工智能·线性代数·算法·机器学习·数学建模·数据挖掘·量子计算
风落无尘6 小时前
《智能重生:从垃圾堆到AI工程师》——第四章 变化的艺术
人工智能·线性代数·算法
JAVA面经实录9176 小时前
计算机基础(完整版·超详细可背诵)
java·linux·数据结构·算法
特种加菲猫6 小时前
继承,一场跨越时空的对话
开发语言·c++
AC赳赳老秦6 小时前
知识产权辅助:用 OpenClaw 批量生成专利交底书 / 软著申请材料,自动校验格式与内容合规性
java·人工智能·python·算法·elasticsearch·deepseek·openclaw