NYOJ-1188并集与交集,STL的灵活运用!

来源:互联网 发布:java九九乘法表编程 编辑:程序博客网 时间:2024/06/08 08:15

并集与交集

时间限制:1000 ms  |  内存限制:65535 KB
难度:2
描述

给你两个字符串的集合A和B,让你求这两个字符串集合的并集和交集,按字典序排序后输出。

然后又给出给出两个字符串s1和s2,然后让你依次输出在并集中满足(s1<=s<=s2)的所有字符串s。(注意:在一个集合中出现的相同字符串只算一个)

输入
多组输入
每组首先两个集合A和B,各占一行,其中包括大小写字母及标点符号。(集合中字符串个数不超过500,每个单词长度不超过20)
然后两个字符串s1和s2,只有大小写字母
输出
输出并集交集,及在其中的字符串。
样例输入
fo buffoon thinkers for heavy can for ametal any food elegant deliver forfood heavy
样例输出
a any buffoon can deliver elegant fo food for heavy metal thinkers for food for heavy 
 

    题意很简单,前两行给出的是两个字符串集合,第三行给出一个区间,求这两个集合的并集与交集及交集中字典序大小在区间内的字符串。

   此题集合元素是字符串,所以很明显用STL做,但具体用哪一种容器,我觉得还是看个人习惯及掌握程度吧,当然,时间复杂度优先考虑。目测此题数据不大,所以set、map 都可以用。博主将用map讲解此题;

   我们知道map有两个键,前为键值(索引),后为索引对应的值,这题我们求的是交集与并集,可以将string串作为索引,出现个数作为值,这样就可以求出交集了,至于并集,我们知道:map容器是按索引的字典序排序的,用一个总的map容器将两个集合的元素全部包含,这样恰好应了题目要求。

   以上就是大致思路,不过具体实现却是坑点巨多。首先是输入要求,用普通的cin肯定是不行的,这里要用到一种getline的函数,具体用法Link1/Link2;这样是整行输入,所以还要提取单词,string字符串有个优点就是字符连接可以直接用‘+’,而不是像数组那样在末端添加值,可以自行试试看看输出结果,博主就是在这耽误了一个多小时。成功提取出来后,求交集不能只看一个容器中的出现次数,而应该两个集合都应出现,所以要用两个单独的容器表示字符串出现过。

#include <map>#include <set>#include <queue>#include <stack>#include <cmath>#include <cstdio>#include <vector>#include <cstring>#include <iostream>#include <algorithm>using namespace std;//const int INF=0x3f3f3f3f;const int N=1000+10;string line1,line2,line3;int main(){    while(getline(cin,line1)&&getline(cin,line2)&&getline(cin,line3))//输入格式    {        map<string,int>q1;        map<string,int>q2;        map<string,int>q3;//总的集合;        string a,b,c;        for(int i=0; i<line1.length(); i++)        {            if(line1[i]==' ')//string 以空格结尾;            {//                cout<<a<<endl;                q1[a]++;                q3[a]++;                a.clear();//别忘了清空;            }            else                a+=line1[i];        }        q1[a]++;        q3[a]++;        a.clear();        for(int i=0; i<line2.length(); i++)        {            if(line2[i]==' ')//string 以空格结尾;            {//                cout<<a<<endl;                q2[a]++;                q3[a]++;                a.clear();            }            else                a+=line2[i];        }        q2[a]++;        q3[a]++;        int f=0;        for(int i=0; i<line3.length(); i++)        {            if(f==0)            {                if(line3[i]==' ') f=1;                else b+=line3[i];            }            else c+=line3[i];        }        for(map<string,int>::iterator it=q3.begin(); it!=q3.end(); it++)            cout<<it->first<<" ";        cout<<endl;        for(map<string,int>::iterator it=q1.begin(); it!=q1.end(); it++)            if(q1[it->first]>=1&&q2[it->first]>=1)//同时出现过才是交集;                cout<<it->first<<" ";        cout<<endl;        for(map<string,int>::iterator it=q3.begin(); it!=q3.end(); it++)            if(it->first>=b&&it->first<=c)                cout<<it->first<<" ";        cout<<endl;    }    return 0;}
千言化作无言,只得勤奋所依!

0 0
原创粉丝点击