• HDU


    题目:

    lily的好朋友xiaoou333最近很空,他想了一件没有什么意义的事情,就是统计一篇文章里不同单词的总数。下面你的任务是帮助xiaoou333解决这个问题。
     
    Input
    有多组数据,每组一行,每组就是一篇小文章。每篇小文章都是由小写字母和空格组成,没有标点符号,遇到#时表示输入结束。
     
    Output
    每组只输出一个整数,其单独成行,该整数代表一篇文章里不同单词的总数。
     
    Sample Input
    you are my friend #
     
    Sample Output
    4
     
     
    利用STL的set,但是需要注意字符串的处理,利用set的特性,建立一个中间字符串变量tmp,把当前单词暂时存在tmp中,根据判断条件(输入的字符串是否为空格或者到了末尾)来判断把tmp存入set中。
    另一个需要注意的就是遍历的for需要从0到字符串最后的后面一个,为了防止什么都没有的情况。
    代码:
    #include<bits/stdc++.h>
    using namespace std;

    set<string> se;

    void word(string str){
        se.clear();
        string tmp="";
        for(int i=0;i<=str.size();i++){
            if(str[i]==' '||i==str.size()){
                if(tmp=="")  continue;
                se.insert(tmp);
                tmp="";
            }
            else  tmp+=str[i];
        }
        cout<<se.size()<<endl;
    }

    int main(){
        string str;
        while(getline(cin,str)&&str[0]!='#')
            word(str);
        return 0;
    }
    该代码来源于杭电讨论区的朋友( 喜欢你的笑声)。
  • 相关阅读:
    Linux常用命令(二)
    C#异步调用
    Ajax运用总结
    SQL Server2005 FOR XML PATH 语句的应用
    SQL Server 2005 处理交叉表
    如何控制并发和控制死锁(内含pb的处理要点)
    WPF 中的换行符
    C#委托的异步调用
    pivot 附近有语法错误,您可能需要将当前数据库的兼容级别设置为更高的值。
    应用系统BUG分布小结
  • 原文地址:https://www.cnblogs.com/sunowsir/p/7255765.html
Copyright © 2020-2023  润新知