C++ set的使用方法詳解
C++ set的使用方法詳解
set也是STL中比較常見的容器。set集合容器實現(xiàn)了紅黑樹的平衡二叉檢索樹的數(shù)據(jù)結(jié)構(gòu),它會自動調(diào)整二叉樹的排列,把元素放到適當?shù)奈恢?。set容器所包含的元素的值是唯一的,集合中的元素按一定的順序排列。
我們構(gòu)造set集合的目的是為了快速的檢索,不可直接去修改鍵值。
set的一些常見操作:
- begin() 返回指向第一個元素的迭代器
- clear() 清除所有元素
- count() 返回某個值元素的個數(shù)
- empty() 如果集合為空,返回true(真)
- end() 返回指向最后一個元素之后的迭代器,不是最后一個元素
- erase() 刪除集合中的元素
- find() 返回一個指向被查找到元素的迭代器
- insert() 在集合中插入元素
- max_size() 返回集合能容納的元素的最大限值
- size() 集合中元素的數(shù)目
- swap() 交換兩個集合變量
其實set的大部分操作是與vector類似的,不過set不支持隨機訪問,必須要使用迭代器去訪問。由于set放入一個元素就會調(diào)整這個元素的位置,把它放到合適的位置,所以set中只有一個insert插入操作。
對于集合來說,我們一般有并集、交集、差集、補集這幾種操作,所以在set的操作中我們也有類似的集合操作,它們都在#include<algorithm>的頭文件下:
std::set_intersection() :這個函數(shù)是求兩個集合的交集。 std::set_union() :求兩個集合的并集 std::set_difference():差集 std::set_symmetric_difference():得到的結(jié)果是 第一個迭代器相對于第二個的差集 并上第二個相對于第一個的差集
學(xué)校OJ上有一個題可以來進行這幾個操作,下面是學(xué)校OJ的題:
Description
集合的運算就是用給定的集合去指定新的集合。設(shè)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
第一行輸入一個正整數(shù)T,表示總共有T組測試數(shù)據(jù)。(T<=200) 然后下面有2T行,每一行都有n+1個數(shù)字,其中第一個數(shù)字是n(0<=n<=100),表示該行后面還有n個數(shù)字輸入。
Output
對于每組測試數(shù)據(jù),首先輸出測試數(shù)據(jù)序號,”Case #.NO”, 接下來輸出共7行,每行都是一個集合, 前2行分別輸出集合A、B,接下5行來分別輸出集合A、B的并(A u B)、交(A n B)、差(A – B)、補。 集合中的元素用“{}”擴起來,且元素之間用“, ”隔開。
Sample Input
14 1 2 3 10
Sample Output
Case# 1: A = {1, 2, 3} B = {} A u B = {1, 2, 3} A n B = {} A - B = {1, 2, 3} SA = {} SB = {1, 2, 3}
我的代碼如下:
#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; }
inserter是一個迭代器適配器中的插入迭代器。原理:其內(nèi)部調(diào)用insert()
功能:在容器的指定位置插入元素
限制:只有提供了inset()成員函數(shù)的容器中,inserter才能派上用場. 所有STL容器都提供了inset()函數(shù).
適用:所有STL容器
如有疑問請留言或到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關(guān)文章
string,CString,char*之間的轉(zhuǎn)化
下面是MFC/C++/C中字符類型CString, int, string, char*之間的轉(zhuǎn)換的說明與舉例,經(jīng)常用的東西,相信對于用C/C++的朋友,還是比較有用的2013-03-03C++圖論之Bellman-Ford算法和SPFA算法的實現(xiàn)
貝爾曼-福特算法(Bellman-Ford)是由理查德·貝爾曼和萊斯特·福特創(chuàng)立的,求解單源最短路徑問題的一種算法。SPFA 算法是 Bellman-Ford算法 的隊列優(yōu)化算法的別稱,通常用于求含負權(quán)邊的單源最短路徑。本文將詳解兩個算法的實現(xiàn),需要的可以參考一下2022-06-06C語言數(shù)據(jù)結(jié)構(gòu)之單鏈表存儲詳解
鏈表是一種物理存儲結(jié)構(gòu)上非連續(xù)、非順序的存儲結(jié)構(gòu),數(shù)據(jù)元素的邏輯順序是通過鏈表中的指針鏈接次序?qū)崿F(xiàn)的。本文將和大家一起聊聊C語言中單鏈表的存儲,感興趣的可以學(xué)習(xí)一下2022-07-07C++ STL入門教程(7) multimap、multiset的使用
這篇文章主要介紹了C++ STL入門教程第七篇,multimap一對多索引,multiset多元集合的使用方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-08-08c語言連接mysql數(shù)據(jù)庫的實現(xiàn)方法
C語言連接mysql數(shù)據(jù)庫,需要相應(yīng)的頭文件和lib文件,如果你安裝Mysql數(shù)據(jù)庫,會在安裝目錄下找到這些庫文件,如果沒有安裝,也可以在網(wǎng)上找到2012-05-05