- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
- 39
- 40
- 41
- 42
- 43
- 44
- 45
- 46
- 47
- 48
三、set 容器
头文件set主要包括set和multiset(两者方法相同,所以以下只用set举例)两个容器,分别是“有序集合”和“有序多重集合”,即前者的元素不能重复,而后者可以包含若干个相等的元素,两者都会将其容器内的元素从小到大自动排序。set和multiset的内部实现是一棵红黑树,它们支持的函数基本相同。(下typename均用int举例)
#include
/*set 生成*/
set st;
/*set 迭代器*/
set::iterator iter
st.begin()
st.end()
/*set 插入*/
st.insert(2); //插入一个元素
/*set 删除*/
st.erase(st.begin()); //删除迭代器指向元素
st.erase(2); //删除所有为2的元素
/*set 容量*/
st.size()
/*set 查找*/
st.find(2) //从前往后找,若找到,返回指向该处的迭代器;反之,返回迭代器st.end()
st.lower_bound(x) //二分查找大于等于x的元素中最小的一个,并返回指向该元素的迭代器。
st.upper_bound(x) //二分查找大于x的元素中最小的一个,并返回指向该元素的迭代器。
/*set 某元素个数*/
st.count(2); //返回容器里2的个数
/*set 判空*/
st.empty() //返回布尔值
/*set 清空*/
st.clear();
class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}">
class="hide-preCode-box">
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
四、queue 容器
头文件queue主要包括循环队列queue和优先队列priority_queue两个容器。其中queue容器相当于队列,满足先进先出的原则,即队尾出、队首进。(以下typename均用int举例)
#include
/*queue 生成*/
queue q;
/*queue 头尾*/
q.front();
q.back();
/*queue 插入*/
q.push(2); //在队尾插入一个元素
/*queue 删除*/
q.pop(); //在队首删除一个元素
/*queue 容量*/
q.size();
/*queue 判空*/
q.empty()
class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}">
class="hide-preCode-box">
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
五、priority_queue 容器
头文件queue主要包括循环队列queue和优先队列priority_queue两个容器。其中priority_queue容器相当于大根堆(或者小根堆),大根堆每次堆顶是最大元素,小根堆每次堆顶是最小元素。(以下typename均用int举例)
#include
/*priority_queue 生成*/
priority_queue q; //大根堆
priority_queue, greater> q; //小根堆
/*priority_queue 插入*/
q.push(2); //把一个元素插入堆
/*priority_queue 删除*/
q.pop(); //删除堆顶的元素
/*priority_queue 堆顶*/
q.top(); //返回堆顶元素
/*priority_queue 容量*/
q.size();
/*priority_queue 判空*/
q.empty()
class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}">
class="hide-preCode-box">
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
六、stack 容器
stack容器相当于栈,满足先进后出的原则,即插入和删除都只能再栈顶操作。(以下typename均用int举例)
#include
/*stack 生成*/
stack sk;
/*stack 插入*/
sk.push(2); //把一个元素放入栈
/*stack 删除*/
sk.pop(); //删除栈顶的元素
/*stack 栈顶*/
sk.top(); //返回栈顶元素
/*stack 容量*/
sk.size();
/*stack 判空*/
sk.empty()
class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}">
class="hide-preCode-box">
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
七、dequeue 容器
双端队列deque是一个支持在两端高效插入或删除元素的连续线性存储空间。它就像是vector和queue的结合。与vector相比,deque在头部增删元素仅需要 O(1)的时间;与queue相比,deque像数组一样支持随机访问。(以下typename均用int举例)
#include
/*dequeue 生成*/
dequeue dq;
/*dequeue 头尾*/
dq.front();
dq.back();
/*dequeue 迭代器*/
dq.begin()
dq.end()
/*dequeue 插入*/
dq.push_front(2); //头插入
dq.push_back(2); //尾插入
/*dequeue 删除*/
dq.pop_front(); //头删除
dq.pop_back(); //尾删除
/*dequeue 容量*/
dq.size();
/*dequeue 判空*/
dq.empty()
/*dequeue 清空*/
dq.clear();
class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}">
class="hide-preCode-box">
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
八、map 容器
map容器是一个键值对key-value的映射,其内部实现是一棵以key为关键码的红黑树。map的key和value可以是任意类型。(以下typename均用int举例)
#include
class="hide-preCode-box">
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
九、pair 容器
pair相当于将两份数据打包成一对,两份数据的数据类型任意,多与其他容器混合使用,单独使用的情况比较少。(以下typename均用int举例)
#include
/*pair 生成*/
pair pr = make_pair(0,1);
pair pr(0, 1);
/*pair 两个值*/
pr.first
pr.second
/*pair 多与其他容器结合使用*/
set> st;
vector> vct(mp.begin(), mp.end());
class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}">
十、bitset 容器
bitset容器相当于是01数组,其方便之处是可以直接按位(下标)进行位运算,但是要注意下标从小到大依次存低位到高位,是逆序的。
#include
/*bitset 生成*/
bitset<4> bt; //生成4位二进制数,初始化为0000
bitset<8> bt(12); //生成8位二进制数,且将10进制数12转化为2进制数存入其中
bitset<8> bt(str); //str可以是只有01的字符串或者字符数组
/*bitset 位运算相关*/
bt1 |= bt2; //两个二进制数取或操作
bt1 &= bt2; //两个二进制数取与操作
bt1 ^= bt2; //取异或
bt1 = ~bt1; //取反
bt1 <<= x; //左移右移
bt.test(x) //判断第x个位置是0还是1,也就是输出第x个位置,注意逆序
bt.flip(); //将二进制每一位取反
bt.flip(x); //将二进制第x位取反
bt.set(); //将二进制每一位置为1
bt.set(x); //将第x个位置置为1
bt.reset(); //将二进制每一位置为0
bt.reset(x); //将第x个位置置为0
/*bitset 容量*/
bt.size() //二进制数组的长度,就是定义的长度;
/*bitset 某元素个数*/
bt.count(); //查询二进制数组中,1的个数
/*bitset 转化字符串*/
string str = bt.to_string(); //将二进制数组转化为字符串。
class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}">
class="hide-preCode-box">
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
data-report-view="{"mod":"1585297308_001","spm":"1001.2101.3001.6548","dest":"https://blog.csdn.net/2203_75327677/article/details/136080887","extend1":"pc","ab":"new"}">>
评论记录:
回复评论: