5-3 安迪的第一本字典

这道题我直接抄了 思路很简单 就是利用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//sstteam 
#include//string 
#include//set 
#include//I/O 
using namespace std;

setdict;//创建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::iterator it = dict.begin(); it != dict.end(); ++it)
        cout << *it <<"\n";
    return 0;
}

你可能感兴趣的:(5-3 安迪的第一本字典)