这道题我直接抄了 思路很简单 就是利用set自动排序且不重复 不过中间还是出现一些小插曲。。。没脸再问学长了...
http://acm.hust.edu.cn/vjudge/contest/128220#problem/C
1 isalpha() tolower()
2 括号中的表达式为了匹配bool类型将自动转换为void*类型。如果读入时发生错误返回0,否则返回cin的地址 http://blog.csdn.net/kongbai308416350/article/details/4470914
3 两个string 不可以直接赋值给另一个 可以用一个流作为媒介 以及除去string里的空格
#include<sstream>//sstteam
#include<string>//string
#include<set>//set
#include<iostream>//I/O
using namespace std;
set<string>dict;//创建set
int main(){
string s, buf;
while(cin>>s){//结尾记得ctrl z 回车
for(int i = 0; i < s.length(); i++){ //遍历 若是字母 则转化为小写 若非字母 则转化为空格
if(isalpha(s[i])) s[i] = tolower(s[i]); else s[i] = ' ';
//dict.insert(s); //在这里插入为什么答案会出现重复? 实际上并没有...有字符...
}
// dict.insert(s); 跟下面一样
stringstream ss(s); //string之间无法直接赋值
while(ss>>buf) dict.insert(buf);
//为什么这里buf即使换成s也行? 还真不行...因为Desneyland前面多了一个空格... 流在传字符的时候以空格结束
}
for(set<string>::iterator it = dict.begin(); it != dict.end(); ++it)
cout << *it <<"\n";
return 0;
}