欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++ set的使用方法詳解

 更新時(shí)間:2017年10月16日 09:16:06   作者:_QING_FENG  
這篇文章主要介紹了C++ set的使用方法詳解的相關(guān)資料,希望通過(guò)本文能幫助到大家,讓大家理解掌握set的使用方法,需要的朋友可以參考下

C++ set的使用方法詳解

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

我們構(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類似的,不過(guò)set不支持隨機(jī)訪問(wèn),必須要使用迭代器去訪問(wèn)。由于set放入一個(gè)元素就會(huì)調(diào)整這個(gè)元素的位置,把它放到合適的位置,所以set中只有一個(gè)insert插入操作。

對(duì)于集合來(lái)說(shuō),我們一般有并集、交集、差集、補(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è)題可以來(lái)進(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組測(cè)試數(shù)據(jù)。(T<=200)
然后下面有2T行,每一行都有n+1個(gè)數(shù)字,其中第一個(gè)數(shù)字是n(0<=n<=100),表示該行后面還有n個(gè)數(shù)字輸入。

Output

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

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才能派上用場(chǎng). 所有STL容器都提供了inset()函數(shù).

適用:所有STL容器

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

相關(guān)文章

  • string,CString,char*之間的轉(zhuǎn)化

    string,CString,char*之間的轉(zhuǎn)化

    下面是MFC/C++/C中字符類型CString, int, string, char*之間的轉(zhuǎn)換的說(shuō)明與舉例,經(jīng)常用的東西,相信對(duì)于用C/C++的朋友,還是比較有用的
    2013-03-03
  • C語(yǔ)言數(shù)據(jù)在內(nèi)存中的存儲(chǔ)詳解

    C語(yǔ)言數(shù)據(jù)在內(nèi)存中的存儲(chǔ)詳解

    本篇文章是C語(yǔ)言編程篇,主要為大家介紹C語(yǔ)言編程中數(shù)據(jù)在內(nèi)存中存儲(chǔ)解析,有需要的朋友可以借鑒參考下,希望可以有所幫助
    2021-09-09
  • C++圖論之Bellman-Ford算法和SPFA算法的實(shí)現(xiàn)

    C++圖論之Bellman-Ford算法和SPFA算法的實(shí)現(xiàn)

    貝爾曼-福特算法(Bellman-Ford)是由理查德·貝爾曼和萊斯特·福特創(chuàng)立的,求解單源最短路徑問(wèn)題的一種算法。SPFA 算法是 Bellman-Ford算法 的隊(duì)列優(yōu)化算法的別稱,通常用于求含負(fù)權(quán)邊的單源最短路徑。本文將詳解兩個(gè)算法的實(shí)現(xiàn),需要的可以參考一下
    2022-06-06
  • C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)之單鏈表存儲(chǔ)詳解

    C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)之單鏈表存儲(chǔ)詳解

    鏈表是一種物理存儲(chǔ)結(jié)構(gòu)上非連續(xù)、非順序的存儲(chǔ)結(jié)構(gòu),數(shù)據(jù)元素的邏輯順序是通過(guò)鏈表中的指針鏈接次序?qū)崿F(xiàn)的。本文將和大家一起聊聊C語(yǔ)言中單鏈表的存儲(chǔ),感興趣的可以學(xué)習(xí)一下
    2022-07-07
  • C語(yǔ)言中各類指針的用法(小結(jié))

    C語(yǔ)言中各類指針的用法(小結(jié))

    這篇文章主要介紹了C語(yǔ)言中各類指針的用法(小結(jié)),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-02-02
  • C++ STL入門教程(7) multimap、multiset的使用

    C++ STL入門教程(7) multimap、multiset的使用

    這篇文章主要介紹了C++ STL入門教程第七篇,multimap一對(duì)多索引,multiset多元集合的使用方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • C語(yǔ)言中程序如何調(diào)用Python腳本

    C語(yǔ)言中程序如何調(diào)用Python腳本

    由于python有很多功能強(qiáng)大的開源庫(kù),有時(shí)候在寫C語(yǔ)言程序的時(shí)候又想利用一下python強(qiáng)大的模塊,那么C語(yǔ)言中程序如何調(diào)用Python腳本,感興趣的小伙伴們可以參考一下
    2021-05-05
  • c語(yǔ)言連接mysql數(shù)據(jù)庫(kù)的實(shí)現(xiàn)方法

    c語(yǔ)言連接mysql數(shù)據(jù)庫(kù)的實(shí)現(xiàn)方法

    C語(yǔ)言連接mysql數(shù)據(jù)庫(kù),需要相應(yīng)的頭文件和lib文件,如果你安裝Mysql數(shù)據(jù)庫(kù),會(huì)在安裝目錄下找到這些庫(kù)文件,如果沒有安裝,也可以在網(wǎng)上找到
    2012-05-05
  • C++實(shí)現(xiàn)LeetCode(47.全排列之二)

    C++實(shí)現(xiàn)LeetCode(47.全排列之二)

    這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(47.全排列之二),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • C語(yǔ)言中的二叉樹和堆詳解

    C語(yǔ)言中的二叉樹和堆詳解

    這篇文章主要介紹了C語(yǔ)言中的二叉樹和堆詳解,樹是一種非線性的數(shù)據(jù)結(jié)構(gòu),它是由n(n>=0)個(gè)有限結(jié)點(diǎn)組成一個(gè)具有層次關(guān)系的集合,把它叫做樹是因?yàn)樗雌饋?lái)像一棵倒掛的樹,也就是說(shuō)它是根朝上,而葉朝下的,需要的朋友可以參考下
    2023-07-07

最新評(píng)論