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<algorithm>的標頭檔案下:
- std::set_intersection() :這個函式是求兩個集合的交集。
- std::set_union() :求兩個集合的並集
- std::set_difference():差集
- std::set_symmetric_difference():得到的結果是 第一個迭代器相對於第二個的差集 並上第二個相對於第一個的差集
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的並(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;
- }
功能:在容器的指定位置插入元素
限制:只有提供了inset()成員函式的容器中,inserter才能派上用場. 所有STL容器都提供了inset()函式.
適用:所有STL容器
相關文章
- 【C++ STL】Set用法C++
- Oracle set unused的用法Oracle
- Python中set的用法Python
- Oracle set unused的用法.sqlOracleSQL
- shell中set指令的用法
- STL:set用法總結
- rman set newname switch 用法
- oracle set的一些整理Oracle
- C++ set and multisetC++
- STL中set用法詳解
- c++中::的用法C++
- MySql的一些用法MySql
- set autotrace的用法和含意及區別
- C++中& 的基本用法C++
- C++ 中特殊的用法C++
- c++ map用法C++
- C++ 函式 realloc 的用法C++函式
- C++中const的用法C++
- C++引用的作用和用法C++
- c#物件導向中的get和set的用法C#物件
- RMAN中SET命令的常見用法的小結 (ZT)
- typedef的一些高階用法
- js陣列的一些用法JS陣列
- ViewStub的一些不常見的用法View
- C++中clock用法C++
- C++中行內函數的用法C++函數
- C++中函式呼叫的用法C++函式
- C++ new用法的個人見解C++
- c++中stack、queue、vector的用法C++
- C和C++陣列的用法C++陣列
- C++ 中dynamic_cast<>的用法C++AST
- axios的一些常見用法iOS
- 關於angularJS的一些用法AngularJS
- DB2一些SQL的用法DB2SQL
- MapStruct的一些常規用法Struct
- 模板字串的一些用法小記字串
- c++ unordered_map/set自定義物件的hashC++物件
- 記錄的一些Retrofit的小用法