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<algorithm>的头文件下:
- std::set_intersection() :这个函数是求两个集合的交集。
- std::set_union() :求两个集合的并集
- std::set_difference():差集
- std::set_symmetric_difference():得到的结果是 第一个迭代器相对于第二个的差集 并上第二个相对于第一个的差集
Description
Input
Output
Sample Input
Sample Output
我的代码如下:
- #include<iostream>
- #include<set>
- #include<algorithm>
- #include<vector>
- using namespace std;
- void print(set<int> a)
- {
- if(a.begin() == a.end())
- cout << "}" << endl;
- for(set<int>::iterator it = a.begin();it!=a.end();it++)
- {
- if(++it==a.end())
- {
- it--;
- cout << *it << "}\n";
- }
- else
- {
- it--;
- cout << *it << ", ";
- }
- }
- }
- int main()
- {
- int T, cou = 0;
- set<int> a, b, c;
- cin >> T;
- while(T--)
- {
- cou++;
- a.clear(), b.clear(), c.clear();
- int n;
- cin >> n;
- for(int i=0;i<n;i++)
- {
- int x;
- cin >> x;
- a.insert(x);
- }
- cin >> n;
- for(int i=0;i<n;i++)
- {
- int x;
- cin >> x;
- b.insert(x);
- }
- cout << "Case# " << cou << ":" << endl;
- cout << "A = {";
- print(a);
- cout << "B = {";
- print(b);
- set_union(a.begin(),a.end(),b.begin(),b.end(),inserter(c,c.begin()));
- cout << "A u B = {";
- print(c);
- c.clear();
- set_intersection(a.begin(),a.end(),b.begin(),b.end(),inserter(c,c.begin()));
- cout << "A n B = {";
- print(c);
- c.clear();
- set_difference(a.begin(),a.end(),b.begin(),b.end(),inserter(c,c.begin()));
- cout << "A - B = {";
- print(c);
- c.clear();
- set_difference(b.begin(),b.end(),a.begin(),a.end(),inserter(c,c.begin()));
- cout << "SA = {";
- print(c);
- c.clear();
- set_difference(a.begin(),a.end(),b.begin(),b.end(),inserter(c,c.begin()));
- cout << "SB = {";
- print(c);
- }
- return 0;
- }
原理:其内部调用insert()
功能:在容器的指定位置插入元素
限制:只有提供了inset()成员函数的容器中,inserter才能派上用场. 所有STL容器都提供了inset()函数.
适用:所有STL容器