日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > c/c++ >内容正文

c/c++

C++ set的一些用法

發(fā)布時間:2023/12/2 c/c++ 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 C++ set的一些用法 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

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

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

set的一些常見操作:

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

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

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

[html] view plain copy
  • 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}
    我的代碼如下: [cpp] view plain copy
  • #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是一個迭代器適配器中的插入迭代器。 原理:其內(nèi)部調(diào)用insert()
    功能:在容器的指定位置插入元素
    限制:只有提供了inset()成員函數(shù)的容器中,inserter才能派上用場. 所有STL容器都提供了inset()函數(shù).
    適用:所有STL容器

    總結

    以上是生活随笔為你收集整理的C++ set的一些用法的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。