C++ set的使用方法详解
C++set的使用方法详解
set也是STL中比较常见的容器。set集合容器实现了红黑树的平衡二叉检索树的数据结构,它会自动调整二叉树的排列,把元素放到适当的位置。set容器所包含的元素的值是唯一的,集合中的元素按一定的顺序排列。
我们构造set集合的目的是为了快速的检索,不可直接去修改键值。
set的一些常见操作:
- begin()返回指向第一个元素的迭代器
- clear()清除所有元素
- count()返回某个值元素的个数
- empty()如果集合为空,返回true(真)
- end()返回指向最后一个元素之后的迭代器,不是最后一个元素
- erase()删除集合中的元素
- find()返回一个指向被查找到元素的迭代器
- insert()在集合中插入元素
- max_size()返回集合能容纳的元素的最大限值
- size()集合中元素的数目
- swap()交换两个集合变量
其实set的大部分操作是与vector类似的,不过set不支持随机访问,必须要使用迭代器去访问。由于set放入一个元素就会调整这个元素的位置,把它放到合适的位置,所以set中只有一个insert插入操作。
对于集合来说,我们一般有并集、交集、差集、补集这几种操作,所以在set的操作中我们也有类似的集合操作,它们都在#include
std::set_intersection():这个函数是求两个集合的交集。 std::set_union():求两个集合的并集 std::set_difference():差集 std::set_symmetric_difference():得到的结果是第一个迭代器相对于第二个的差集并上第二个相对于第一个的差集
学校OJ上有一个题可以来进行这几个操作,下面是学校OJ的题:
Description
集合的运算就是用给定的集合去指定新的集合。设A和B是集合,则它们的并差交补集分别定义如下: A∪B={x|x∈A∨x∈B} A∩B={x|x∈A∧x∈B} A-B={x|x∈A∧x不属于B} SA={x|x∈(A∪B)∧x不属于A} SB={x|x∈(A∪B)∧x不属于B}
Input
第一行输入一个正整数T,表示总共有T组测试数据。(T<=200) 然后下面有2T行,每一行都有n+1个数字,其中第一个数字是n(0<=n<=100),表示该行后面还有n个数字输入。
Output
对于每组测试数据,首先输出测试数据序号,”Case#.NO”, 接下来输出共7行,每行都是一个集合, 前2行分别输出集合A、B,接下5行来分别输出集合A、B的并(AuB)、交(AnB)、差(A–B)、补。 集合中的元素用“{}”扩起来,且元素之间用“,”隔开。
SampleInput
1412310
SampleOutput
Case#1: A={1,2,3} B={} AuB={1,2,3} AnB={} A-B={1,2,3} SA={} SB={1,2,3}
我的代码如下:
#include#include #include #include usingnamespacestd; voidprint(set a) { if(a.begin()==a.end()) cout<<"}"< ::iteratorit=a.begin();it!=a.end();it++) { if(++it==a.end()) { it--; cout<<*it<<"}\n"; } else { it--; cout<<*it<<","; } } } intmain() { intT,cou=0; set a,b,c; cin>>T; while(T--) { cou++; a.clear(),b.clear(),c.clear(); intn; cin>>n; for(inti=0;i >x; a.insert(x); } cin>>n; for(inti=0;i >x; b.insert(x); } cout<<"Case#"< inserter是一个迭代器适配器中的插入迭代器。原理:其内部调用insert()
功能:在容器的指定位置插入元素
限制:只有提供了inset()成员函数的容器中,inserter才能派上用场.所有STL容器都提供了inset()函数.
适用:所有STL容器
如有疑问请留言或到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!