并集与交集

时间限制: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 a
metal any food elegant deliver for
food 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;
}

千言化作无言,只得勤奋所依!

NYOJ-1188并集与交集,STL的灵活运用!的更多相关文章

  1. List之Union(),Intersect(),Except() 即并集,交集,差集运算。

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...

  2. java8 集合求差集、并集、交集

    前言 java8里最大亮点是lambda,让我们用习惯C# linq的语法,也能眼前一亮.但是比起C#的语法糖还是差的很远. 差集.并集.交集 @Test public void test1(){ L ...

  3. PHP求并集,交集,差集

    PHP求并集,交集,差集 一.总结 一句话总结:在php中如果我想要对两个数组进行如并集.交集和差集操作,我们可直接使用php自带的函数来操作如array_merge(),array_intersec ...

  4. python 并集union, 交集intersection, 差集difference, 对称差集symmetric_difference

    python的集合set和其他语言类似,是一个无序不重复元素集, 可用于消除重复元素. 支持union(联合), intersection(交), difference(差)和sysmmetric d ...

  5. css的高级选择器,后代选择器,子代选择器,并集选择器,交集选择器

    高级选择器: 后代选择器 子代选择器 并集选择器 交集选择器 一.后代选择器: 使用空格表示后代选择器,父元素的后代(包括儿子,孙子,从孙子) 也就是说,box类下的所有span标签 字体颜色都被设置 ...

  6. js数组并集,交集,差集

    js数组并集,交集,差集的计算方式汇总 一. new Set 方式实现 这种方式实现起来比较简单,原理就是参考new Set可以去重的功能 ,关于去重可以点击 https://www.haorooms ...

  7. Python3.7.1学习(三)求两个list的差集、并集与交集

    在python3.7.1对列表的处理中,会经常使用到Python求两个list的差集.交集与并集的方法. 下面就以实例形式对此加以分析. # 求两个list的差集.并集与交集# 一.两个list差集# ...

  8. JS 对象 数组求并集,交集和差集

    一.JS数组求并集,交集和差集 需求场景 最近,自己项目中有一些数组操作,涉及到一些数学集的运算,趁着完成后总结一下. 简化问题之后,现有两数组a = [1, 2, 3],b = [2, 4, 5], ...

  9. Java集合List-差集、并集、交集

    Java集合List的差集.并集.交集 转载于:https://www.cnblogs.com/qlqwjy/p/9812919.html 一.List的差集 @Test public void te ...

随机推荐

  1. 题解报告:poj 2559 Largest Rectangle in a Histogram(单调栈)

    Description A histogram is a polygon composed of a sequence of rectangles aligned at a common base l ...

  2. Unity笔记(4)自学第六天

    今天主要是写了demo的策划案 [关卡设计部分]: [关卡数值设计]:

  3. applicationContext.getBean(“loginEntity”)

    <!-- 指定Spring需要扫描的包,并将所有是别的类放到容器中,便于识别被注解的受托管bean --> <context:component-scan base-package= ...

  4. Python学习 Day 9 property 多重继承 Mixin

    在绑定属性时,如果我们直接把属性暴露出去,虽然写起来很简单,但是,没办法检查参数,导致可以把成绩随便改: s = Student() s.score = 9999 为了限制score的范围,可以通过一 ...

  5. 对象输入输出流ObjectInputStream、ObjectOutputStream(对象序列化与反序列化)

    对象的输入输出流 : 主要的作用是用于写入对象信息与读取对象信息. 对象信息一旦写到文件上那么对象的信息就可以做到持久化了 对象的输出流: ObjectOutputStream 对象的输入流:  Ob ...

  6. Winform中ListView鼠标移动使用toolTip显示信息

    今天在做一个酒店管理系统的时候用到了ListView,突然想到是否能够当鼠标移动到某一项的时候给出具体房间的信息呢! 首先设置Listview的MouseMove事件 1.获取当前坐标的项 ListV ...

  7. CAD参数绘制多段线(网页版)

    多段线又被称为多义线,表示一起画的都是连在一起的一个复合对象,可以是直线也可以是圆弧并且它们还可以加不同的宽度. 主要用到函数说明: _DMxDrawX::PathLineTo 把路径下一个点移到指定 ...

  8. 07JavaScript数组与字符串对象

    JavaScript数组与字符串对象 5.1.1数组(Array)对象 <script> //声明一个数组并赋值; var arr = new Array("aa",& ...

  9. day02 python函数基础

    '''''''''列表: 定义: 在[]内,可以存放多个任意类型的值, 并以逗号隔开. 一般用于存放学生的爱好,课堂的周期等等...'''# 定义一个学生列表,可存放多个学生# list(['钱垚', ...

  10. 去掉PhpStorm打开自动启动的项目

    有时候启动的项目很大,导致很卡,而且在编辑器中更改也没效果,简单暴力的办法 找到项目的目录,删除其中的.idea文件夹