zoukankan      html  css  js  c++  java
  • 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;
    }
    该代码来源于杭电讨论区的朋友( 喜欢你的笑声)。
  • 相关阅读:
    Centos7安装Python3
    mysql+centos7+主从复制
    Python开发之virtualenv和virtualenvwrapper详解
    Linux基础系统优化(二)
    Linux基础系统优化(一)
    Windows 10版本区别
    HTML5常用的语义化标签
    关于efk多服务器多日志合并收集
    离线状态安装docker容器
    Docker部署jenkins+sonar+gitlab代码检测系统
  • 原文地址:https://www.cnblogs.com/sunowsir/p/7255765.html
Copyright © 2011-2022 走看看