题目描述:

输入一个英文句子,把句子中的单词(不区分大小写)按出现次数按从多到少把单词和次数在屏幕上输出来,要求能识别英文句号和逗号,即是说单词由空格、句号和逗号隔开。

输入描述:


输入有若干行,总计不超过1000个字符。


输出描述:


输出格式参见样例。


输入样例:

A blockhouse is a small castle that has four openings through which to shoot.

输出样例:

a:2
blockhouse:1
castle:1
four:1
has:1
is:1
openings:1
shoot:1
small:1
that:1
through:1
to:1
which:1

解题思路:

我一开始的思路是:先把字符串中的字母全部转换成小写,用map来记录单词出现的次数,利用字符流来进行单词的读入,然后进行无脑输出即可。然而!提交之后有测试点WA啦!因为我没有考虑到标点符号的问题,比如:"This is a dog, and that is also a dog."这个句子。我们预期的输出应该包括"dog:2",然而实际的输出结果是"dog,:1"和"dog.:1"。不要慌!

单词识别_字符流

单词识别_c++_02

不要慌问题不大!通过观察可以发现' '、','、'.'这三个字符都标志着一个单词的结束,所以我们可以用一个字符串word来读取单词,然后无脑遍历字符串str,当读到那三个字符时,立即m[word]++;并把word重新置为空,否则将字符添加到word中。

AC代码:WA代码:

#include <bits/stdc++.h>
using namespace std;

int main()
{
    string str,word;
    getline(cin,str);
    transform(str.begin(),str.end(),str.begin(),::tolower);   //把字符串全部转换成小写
    stringstream ss;
    ss << str;   //将字符串str存入字符流中
    map<string,int> m;   //map的key为单词,value为这个单词出现的次数
    while(ss >> word)
    {
        m[word]++;
    }
    for(auto it = m.begin(); it != m.end(); it++)
    {
        cout << it->first << ":" << it->second << endl;
    }
    return 0;
}

AC代码:

#include <bits/stdc++.h>
using namespace std;

int main()
{
    string str, word = "";
    getline(cin,str);
    transform(str.begin(),str.end(),str.begin(),::tolower);   //把字符串全部转换成小写
    map<string,int> m;   //map的key为单词,value为这个单词出现的次数
    for(auto it : str)
    {
        if(it == ' ' || it == ',' || it == '.')   //标志着一个单词的结束
        {
            if(word != "")
            {
                m[word]++;
            }
            word = "";    //将word置为空,开始记录下一个单词
        }
        else
        {
            word += it;
        }
    }
    for(auto it = m.begin(); it != m.end(); it++)
    {
        cout << it->first << ":" << it->second << endl;
    }
    return 0;
}