雷火电竞-中国电竞赛事及体育赛事平台

歡迎來到入門教程網(wǎng)!

C語言

當前位置:主頁 > 軟件編程 > C語言 >

C++ set的使用方法詳解

來源:本站原創(chuàng)|時間:2020-01-10|欄目:C語言|點擊:

C++ set的使用方法詳解

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

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

set的一些常見操作:

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

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

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



std::set_intersection() :這個函數(shù)是求兩個集合的交集。 
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

第一行輸入一個正整數(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是一個迭代器適配器中的插入迭代器。原理:其內部調用insert()

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

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

適用:所有STL容器

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

上一篇:C++中構造函數(shù)的參數(shù)缺省的詳解

欄    目:C語言

下一篇:zlib庫壓縮和解壓字符串STL string的實例詳解

本文標題:C++ set的使用方法詳解

本文地址:http://www.jygsgssxh.com/a1/Cyuyan/1084.html

網(wǎng)頁制作CMS教程網(wǎng)絡編程軟件編程腳本語言數(shù)據(jù)庫服務器

如果侵犯了您的權利,請與我們聯(lián)系,我們將在24小時內進行處理、任何非本站因素導致的法律后果,本站均不負任何責任。

聯(lián)系QQ:835971066 | 郵箱:835971066#qq.com(#換成@)

Copyright © 2002-2020 腳本教程網(wǎng) 版權所有