这道题目是紫书P112页的题目,作者在这里,用于set的入门题目,mark一下
题目大意:给你一段文本,之后把单词不分大小写地按字典序输出,注意:相同的单词只出现一次
#include <cstdio>
#include <iostream>
#include <set>
#include <sstream>
#include <string>
using namespace std;
set<string>dic;
int main()
{
string s,buf;
while(cin>>s)
{
for(int i=0;i<s.length();i++)
if(isalpha(s[i])) s[i]=tolower(s[i]);
else s[i]=' ';
stringstream ss(s);
cout<<ss<<endl;
while(ss>>buf)
dic.insert(buf);
}
for(set<string>::iterator it=dic.begin();it!=dic.end();it++)
cout<<*it<<endl;
return 0;
}
说明:加入集合之后,本身set就已经排好序了,所以不用自己再排序,最后输出就行了;
小技巧:题目上说的只输出单词,所以给其他的字符都当做空格,之后一个一个的个他们加入到set中
关于stringstream:是C++里边的类,可以通过流来实现字符串和数字的转换,下边的一段程序课以清楚地展示这个类的作用
#include <string>
#include <sstream>
#include <iostream>
using namespace std;
int main()
{
string s = "s ss 3 aaa";
stringstream ss;
ss<<s;
while(ss>>s){
cout<<s<<endl;
}
return 0;
}
这下可以很清楚地 看到的stringstream的作用了吧?
你是不是觉得世界就只剩你自己了?