亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

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

C++ set的使用方法詳解

2020-05-23 13:37:37
字體:
來源:轉載
供稿:網友

C++ set的使用方法詳解

set也是STL中比較常見的容器。set集合容器實現了紅黑樹的平衡二叉檢索樹的數據結構,它會自動調整二叉樹的排列,把元素放到適當的位置。set容器所包含的元素的值是唯一的,集合中的元素按一定的順序排列。

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

set的一些常見操作:

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

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

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

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

學校OJ上有一個題可以來進行這幾個操作,下面是學校OJ的題:

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; } 

inserter是一個迭代器適配器中的插入迭代器。原理:其內部調用insert()

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

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

適用:所有STL容器

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


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲欧洲成视频免费观看| 欧美精品日韩三级| 亚洲女人初尝黑人巨大| 国产亚洲欧美另类中文| 国产日本欧美一区二区三区| 欧美一区亚洲一区| 青青a在线精品免费观看| 欧美日韩福利在线观看| 日韩欧美在线国产| 亚洲韩国欧洲国产日产av| 欧美激情视频免费观看| 久久免费国产视频| 欧美老女人性视频| 成人女保姆的销魂服务| 色综合男人天堂| 91在线观看免费观看| 在线视频日本亚洲性| 亚洲国产精品高清久久久| 亚洲欧洲国产精品| 久久久久久国产精品三级玉女聊斋| 亚洲视频一区二区三区| 国产日韩在线播放| 欧美激情精品久久久久久免费印度| 久久久中文字幕| 97激碰免费视频| 成人情趣片在线观看免费| 欧美激情视频给我| 日韩欧美国产成人| 久久久久久久久网站| 日韩中文字幕视频在线| 国产免费一区二区三区香蕉精| 日韩毛片在线看| 欧美天堂在线观看| 国产亚洲精品va在线观看| 久久精品国产亚洲7777| 欧美大胆在线视频| 欧美最顶级丰满的aⅴ艳星| 欧美黑人巨大xxx极品| 亚洲视频视频在线| 成人在线中文字幕| 日韩高清欧美高清| 亚洲精品影视在线观看| 欧美日韩国产综合新一区| 成人h视频在线观看播放| 久久精品欧美视频| 国产精品久久久久久婷婷天堂| 96sao精品视频在线观看| 欧美黑人xxxx| 8090成年在线看片午夜| 亚洲精品中文字幕女同| 国产一区二区三区免费视频| 欧美另类交人妖| 97热精品视频官网| 国产婷婷成人久久av免费高清| 色偷偷888欧美精品久久久| 人人做人人澡人人爽欧美| 成人免费在线视频网址| 亚洲性线免费观看视频成熟| 国产精品亚洲精品| 欧美精品久久久久久久久| 欧美视频免费在线| 国产精品精品久久久久久| 亚洲一区二区三区视频播放| 最近2019好看的中文字幕免费| 91久久久久久久久久久久久| 少妇高潮 亚洲精品| 国产精品视频专区| 日韩大胆人体377p| 国产亚洲一区二区精品| 欧美亚洲另类视频| 日韩国产中文字幕| 国产亚洲精品一区二555| 欧美激情一级精品国产| 亚洲男人天堂2024| 国内精品模特av私拍在线观看| 96sao精品视频在线观看| 亚洲欧洲日韩国产| 久久精品国产免费观看| 欧美国产亚洲精品久久久8v| 国产精品精品久久久久久| 88国产精品欧美一区二区三区| 日韩在线欧美在线| 一区二区三区精品99久久| 668精品在线视频| 欧美精品午夜视频| 日韩综合视频在线观看| 欧美精品性视频| 国产精品福利无圣光在线一区| 亚洲欧美激情视频| 日本久久久久久久久| 国产精品电影网| 国产精品海角社区在线观看| 久久久久久久久久久免费| 亚洲欧美一区二区三区久久| 国产欧美在线播放| 疯狂做受xxxx高潮欧美日本| 亚洲精品ady| 亚洲视频欧美视频| 97av在线播放| 欧美午夜片在线免费观看| 亚洲一区二区久久| 国产亚洲精品久久久优势| 亚洲qvod图片区电影| 国产美女久久精品香蕉69| 欧美久久精品午夜青青大伊人| 在线看日韩欧美| 亚洲美女精品成人在线视频| 日韩经典一区二区三区| 97超视频免费观看| 久久久精品免费| 国产香蕉97碰碰久久人人| 热久久视久久精品18亚洲精品| 亚洲人成绝费网站色www| 91精品视频一区| 亚洲欧美制服丝袜| 97在线看免费观看视频在线观看| 国产精品久久久久久一区二区| 日韩电影视频免费| 久久久久亚洲精品成人网小说| 国产在线久久久| 欧美性高潮在线| 性欧美xxxx| 亚洲一区二区中文| 色av吧综合网| 911国产网站尤物在线观看| 亚洲欧美成人精品| 国外日韩电影在线观看| 成人久久精品视频| 亚洲男人av电影| 狠狠躁天天躁日日躁欧美| 日本中文字幕久久看| 影音先锋欧美精品| 九九热视频这里只有精品| 亚洲欧美一区二区激情| 精品日本高清在线播放| 亚洲精品电影网在线观看| 欧美最近摘花xxxx摘花| 欧美日韩xxxxx| 日韩av电影手机在线观看| 精品久久久av| 亚洲国产日韩精品在线| 国产精品久久久久久久久久三级| 中文字幕亚洲二区| 精品自拍视频在线观看| 欧美极品第一页| 国产精品扒开腿做爽爽爽视频| 亚洲精品乱码久久久久久按摩观| 亚洲乱码av中文一区二区| 国产一区二区丝袜高跟鞋图片| 日韩在线不卡视频| 国产美女扒开尿口久久久| 欧美性猛交xxxx黑人| 国产一区二区激情| 久久精品国产成人| 久久久中精品2020中文| 日韩av免费网站| 久久精品国产亚洲| 91久久精品美女| 精品日韩视频在线观看| 欧美性xxxx在线播放| 亚洲奶大毛多的老太婆| 精品久久久香蕉免费精品视频| 国产精品一区二区av影院萌芽| 久久影视电视剧免费网站|