C++ 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的一些常見操作:
- begin() 返回指向第一個(gè)元素的迭代器
- clear() 清除所有元素
- count() 返回某個(gè)值元素的個(gè)數(shù)
- empty() 如果集合為空,返回true(真)
- end() 返回指向最后一個(gè)元素之后的迭代器,不是最后一個(gè)元素
- erase() 刪除集合中的元素
- find() 返回一個(gè)指向被查找到元素的迭代器
- insert() 在集合中插入元素
- max_size() 返回集合能容納的元素的最大限值
- size() 集合中元素的數(shù)目
- 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)文章
VC++中HTControl的CHTButton按鈕控件類用法實(shí)例解析
這篇文章主要介紹了VC++中HTControl的CHTButton按鈕控件類用法,對(duì)于大家進(jìn)行VC++項(xiàng)目開發(fā)有一定的幫助作用,需要的朋友可以參考下2014-08-08
DSP中浮點(diǎn)轉(zhuǎn)定點(diǎn)運(yùn)算--浮點(diǎn)數(shù)的存儲(chǔ)格式
本文主要介紹DSP中浮點(diǎn)數(shù)的存儲(chǔ)格式,很值得學(xué)習(xí)一下,需要的朋友可以參考一下。2016-06-06
C++實(shí)現(xiàn)LeetCode(101.判斷對(duì)稱樹)
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(101.判斷對(duì)稱樹),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07
C++?STL標(biāo)準(zhǔn)庫(kù)之std::list使用介紹及用法詳解
std::list是支持常數(shù)時(shí)間從容器任何位置插入和移除元素的容器,下面這篇文章主要給大家介紹了關(guān)于C++?STL標(biāo)準(zhǔn)庫(kù)之std::list使用介紹及用法詳解的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-11-11
C++11 std::shared_ptr總結(jié)與使用示例代碼詳解
這篇文章主要介紹了C++11 std::shared_ptr總結(jié)與使用,本文通過(guò)示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-06-06

