题目:输入一段文本,找出所有的不同的单词,按字典序从小到大输出
本题用的关于set的解答,主要是看在set中元素已经从小到大排好顺序的特点解答
输入案例
Adventures in Disneyland
Two blondes were going to Disneyland when they came to a fork in the road. The sign read: “Disneyland Left.”
So they went home.
#include<iostream>
#include<string>
#include<set>
#include<sstream>
using namespace std;
set<string> dict;//string 集合
int main() {
string s, b;
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);
while (ss >> b)
dict.insert(b);
}
for (set<string>::iterator it = dict.begin(); it != dict.end(); ++it)//用迭代器取出set文件里面的
cout << *it << endl;
system("pause");
return 0;
}
输出案列如图:
stringstream ss(s)这行代码是定义一个字符串流ss,并用s去初始化ss
while (ss >> b)是从字符串流读出一个字符串到buf中遇到空格就停止
while (cin >> s)的Windows下终止标志是ctrl+z回车就结束了输入