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
- NYOJ-1188并集与交集,STL的灵活运用!
- STL算法交集、并集、差集
- STL之交集、并集、差集
- 并查集:HDU5326-Work(并查集比较简单灵活的运用)
- 泛型与对象的灵活运用
- POJ - 1338 Ugly Numbers-STL的灵活运用
- 取两个字符串的并集与交集的函数
- 两个有序数组交集与并集的实现
- 求两集合的交集与并集
- STL容器[28]交集、并集、差集
- STL算法-交集,并集,差集,对称差
- STL算法-交集,并集,差集,对称差
- STL算法-交集,并集,差集,对称差
- MathTypy的灵活运用
- onMouseover的灵活运用
- javascript “||”、“&&”的灵活运用
- MathType的灵活运用
- javascript “||”、“&&”的灵活运用
- ViewPage无限轮播小点设置
- c++11多线程生产者消费者问题
- php中的trait
- 安卓用Fragment+RadioButton组合构成的底部导航栏的实现
- 关于javaScript Array数组方法的应用
- NYOJ-1188并集与交集,STL的灵活运用!
- day8-23(JDBC)
- 内积和外积
- Visual Studio+QT+OpenCv实现视频拍照保存功能
- Qt主界面和一个新的Dialog的通信(交互)
- 定义Retrofit 网络接口服务的包装类(基础类)
- oracle 内连接(inner join)、外连接(outer join)、全连接(full join)
- Spring表单提交和页面数据显示的请求处理大致过程
- 217. Contains Duplicate