1.所需的知识:
unordered容器的基本认识和初步使用
stringstream的相关知识
2.代码实现
#include<iostream>
#include<sstream>
#include<fstream>
#include<string>
#include<iterator>
#include<unordered_map>
#include <stdio.h>
using namespace std;
//介绍unordered容器:键值和数据,可通过键值来直接找到数据
//unordered_map<string, int>
unordered_map<string, int> strMap; //用于保存结果
void countword(stringstream& ss)
{
string tmp;
while (ss >> tmp) //将stringstream ss的字符串以空格为间隔的单词放入tmp中
{
unordered_map<string, int>::iterator it = strMap.find(tmp);
if (it == strMap.end())
{
strMap.insert(unordered_map<string, int>::value_type(tmp, 1)); //通过迭代器将新的键值tmp和数据1放入容器
}
else
{
strMap[tmp]++;
}
}
}
int main()
{
//读入字符串
string str1;
cout << "enter a string :";
getline(cin,str1); //要用getline()函数输入带空格的字符串,cin无法输入带空格的字符串
//去除符号
for (int i = 0; i < str1.length(); i++) //字符串的长度str1.legnth()
{
if (int(str1[i]) < 64 && int(str1[i]) > 91 || int(str1[i]) < 96 && int(str1[i]) > 122)
{
str1[i] =' '; //在c++中单引号表示字符双引号表示字符串
}
}
//进行统计
stringstream ss(str1); //stringstream类型的ss获取str1的字符串数据
countword(ss);
//打印
unordered_map<string, int>::iterator it = strMap.begin();
for (it;it != strMap.end(); it++)
{
cout << "单词:" << it->first <<"出现了" << it->second<<"次";
cout << endl;
}
}