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的題:
#includeinserter是一個迭代器適配器中的插入迭代器。#include #include #include using namespace std; void print(set a) { if(a.begin() == a.end()) cout << "}" << endl; for(set ::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 a, b, c; cin >> T; while(T--) { cou++; a.clear(), b.clear(), c.clear(); int n; cin >> n; for(int i=0;i > x; a.insert(x); } cin >> n; for(int i=0;i > 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容器