C++ set的使用方法詳解
set也是STL中比較常見的容器。set集合容器實(shí)現(xiàn)了紅黑樹的平衡二叉檢索樹的數(shù)據(jù)結(jié)構(gòu),它會(huì)自動(dòng)調(diào)整二叉樹的排列,把元素放到適當(dāng)?shù)奈恢谩et容器所包含的元素的值是唯一的,集合中的元素按一定的順序排列。
我們構(gòu)造set集合的目的是為了快速的檢索,不可直接去修改鍵值。
set的一些常見操作:
其實(shí)set的大部分操作是與vector類似的,不過set不支持隨機(jī)訪問,必須要使用迭代器去訪問。由于set放入一個(gè)元素就會(huì)調(diào)整這個(gè)元素的位置,把它放到合適的位置,所以set中只有一個(gè)insert插入操作。
對(duì)于集合來說,我們一般有并集、交集、差集、補(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è)題可以來進(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”,接下來輸出共7行,每行都是一個(gè)集合,前2行分別輸出集合A、B,接下5行來分別輸出集合A、B的并(A u B)、交(A n B)、差(A 主站蜘蛛池模板: 平乡县| 浙江省| 五峰| 加查县| 弥渡县| 兴文县| 普洱| 松潘县| 前郭尔| 乐亭县| 万盛区| 斗六市| 辽源市| 陈巴尔虎旗| 儋州市| 德昌县| 丰县| 通城县| 扎兰屯市| 丽水市| 内江市| 贵溪市| 桃园县| 栾川县| 循化| 左贡县| 万全县| 海南省| 景洪市| 突泉县| 广饶县| 林周县| 陇南市| 新疆| 宜宾县| 渝中区| 漳平市| 抚宁县| 闽侯县| 唐海县| 盘山县|