国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C++ > 正文

C++ set的使用方法詳解

2020-05-23 13:37:37
字體:
供稿:網(wǎng)友

C++ set的使用方法詳解

set也是STL中比較常見的容器。set集合容器實(shí)現(xiàn)了紅黑樹的平衡二叉檢索樹的數(shù)據(jù)結(jié)構(gòu),它會(huì)自動(dòng)調(diào)整二叉樹的排列,把元素放到適當(dāng)?shù)奈恢谩et容器所包含的元素的值是唯一的,集合中的元素按一定的順序排列。

我們構(gòu)造set集合的目的是為了快速的檢索,不可直接去修改鍵值。

set的一些常見操作:

  1. begin() 返回指向第一個(gè)元素的迭代器
  2. clear() 清除所有元素
  3. count() 返回某個(gè)值元素的個(gè)數(shù)
  4. empty() 如果集合為空,返回true(真)
  5. end() 返回指向最后一個(gè)元素之后的迭代器,不是最后一個(gè)元素
  6. erase() 刪除集合中的元素
  7. find() 返回一個(gè)指向被查找到元素的迭代器
  8. insert() 在集合中插入元素
  9. max_size() 返回集合能容納的元素的最大限值
  10. size() 集合中元素的數(shù)目
  11. swap() 交換兩個(gè)集合變量

其實(shí)set的大部分操作是與vector類似的,不過set不支持隨機(jī)訪問,必須要使用迭代器去訪問。由于set放入一個(gè)元素就會(huì)調(diào)整這個(gè)元素的位置,把它放到合適的位置,所以set中只有一個(gè)insert插入操作。

對(duì)于集合來說,我們一般有并集、交集、差集、補(bǔ)集這幾種操作,所以在set的操作中我們也有類似的集合操作,它們都在#include<algorithm>的頭文件下:

std::set_intersection() :這個(gè)函數(shù)是求兩個(gè)集合的交集。 std::set_union() :求兩個(gè)集合的并集 std::set_difference():差集 std::set_symmetric_difference():得到的結(jié)果是 第一個(gè)迭代器相對(duì)于第二個(gè)的差集 并上第二個(gè)相對(duì)于第一個(gè)的差集 

學(xué)校OJ上有一個(gè)題可以來進(jìn)行這幾個(gè)操作,下面是學(xué)校OJ的題:

Description

集合的運(yùn)算就是用給定的集合去指定新的集合。設(shè)A和B是集合,則它們的并差交補(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

第一行輸入一個(gè)正整數(shù)T,表示總共有T組測試數(shù)據(jù)。(T<=200)然后下面有2T行,每一行都有n+1個(gè)數(shù)字,其中第一個(gè)數(shù)字是n(0<=n<=100),表示該行后面還有n個(gè)數(shù)字輸入。

Output

對(duì)于每組測試數(shù)據(jù),首先輸出測試數(shù)據(jù)序號(hào),”Case #.NO”,接下來輸出共7行,每行都是一個(gè)集合,前2行分別輸出集合A、B,接下5行來分別輸出集合A、B的并(A u B)、交(A n B)、差(A – B)、補(bǔ)。集合中的元素用“{}”擴(kuò)起來,且元素之間用“, ”隔開。

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是一個(gè)迭代器適配器中的插入迭代器。原理:其內(nèi)部調(diào)用insert()

功能:在容器的指定位置插入元素

限制:只有提供了inset()成員函數(shù)的容器中,inserter才能派上用場. 所有STL容器都提供了inset()函數(shù).

適用:所有STL容器

如有疑問請(qǐng)留言或到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!


發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 淮安市| 芒康县| 莱州市| 江山市| 阳谷县| 乐业县| 盐池县| 三河市| 濮阳县| 柳州市| 高台县| 濮阳市| 正镶白旗| 广水市| 海南省| 遵义市| 巴东县| 朝阳县| 登封市| 洪洞县| 阿尔山市| 石渠县| 黑山县| 宁南县| 青神县| 皮山县| 安多县| 昆明市| 贵德县| 洛川县| 油尖旺区| 墨竹工卡县| 马鞍山市| 鹤壁市| 扬州市| 新巴尔虎左旗| 乳源| 海南省| 银川市| 洛隆县| 和田县|