ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

安迪的第一个字典

2020-01-28 18:42:32  阅读:336  来源: 互联网

标签:第一个 单词 安迪 dict include buf 从小到大 字典


Uva 10815 - 安迪的第一个字典

输入一个文本,找出所有不同单词(连续的字母序列),按字典序从小到大输出,不区分大小写。

样例输入:
Adventure in Disneyland.
Two blonds were going to Disneyland when they came to a fork in the road.
The sign read: “Disneyland Left”.
So they went home.
样例输出:(只保留前五行)
a
adventure
blonds
came
disneyland

  • 利用 set 中元素已经从小到大排好的性质,用一个for循环即可从小到大遍历所有元素。输入时把所有非字母的字符全部变成空格,然后利用stringstream得到各个单词
#include<iostream>
#include<string>
#include<set>
#include<sstream>
using namespace std;

int main()
{
    string s,buf;
    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>>buf)
                dict.insert(buf);
    }
    for(set<string>::iterator it=dict.begin();it!=dict.end();it++)
        cout<<*it<<endl;
    return 0;
}

这个程序我不知道该怎么运行,但是我们可以感受set这一容器的强大。这是算法竞赛入门经典的一道例题。下面有一个可以自己运行的相对简单的题。

单词排序

小红学会了很多英语单词,妈妈为了帮小红加强记忆,拿出纸、笔,把n个单词写在纸上的一行里,让小红看几秒钟后,将这张纸扣在桌子上。妈妈问小红:你能否将这些n个单词按照字典排列的顺序,从小到大写出来?小红按照妈妈的要求写出了答案。现在请你编写程序帮助妈妈检查小红的答案是否正确。注意:所有单词都由小写字母组成,开头字母全都不同,单词两两之间用一个空格分隔。
Input
输入有两行:第一行仅包含一个正整数n
Output
输出仅有一行:针对妈妈写出的单词,按照字典排列的顺序从小到大排成一行的结果,单词两两之间用一个空格分隔。
Sample Input:
4
city boy tree student
Sample Output:
boy city student tree

  • 解法与上面的例题类似,不需要再进行大小写的转换。
#include<iostream>
#include<string>
#include<set>
#include<sstream>
using namespace std;
int main()
{
    string s,buf;
    int n;
    cin>>n;
    while(n--)
    {
        cin>>s;
        stringstream ss(s);
        ss>>buf;
        dict.insert(buf);
    }
    for(set<string>::iterator it=dict.begin();it!=dict.end();it++)
        cout<<*it<<" ";
    return 0;
酷毙少男 发布了26 篇原创文章 · 获赞 0 · 访问量 361 私信 关注

标签:第一个,单词,安迪,dict,include,buf,从小到大,字典
来源: https://blog.csdn.net/weixin_43614026/article/details/104101260

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有