■ 配接器
栈(stack)
empty() 堆栈为空则返回真
pop() 移除栈顶元素
push() 在栈顶增加元素
size() 返回栈中元素数目
top() 返回栈顶元素
队列(queue)
back()返回最后一个元素
empty()如果队列空则返回真
front()返回第一个元素
pop()删除第一个元素
push()在末尾加入一个元素
size()返回队列中元素的个数
■ 容器
各容器特点
vector 头部与中间插入和删除效率较低,在尾部插入和删除效率高,支持随机访问。
deque 是在头部和尾部插入和删除效率较高,支持随机访问,但效率没有 vector 高。
list 在任意位置的插入和删除效率都较高,但不支持随机访问。
set 由红黑树实现,其内部元素依据其值自动排序,每个元素值只能出现一次,不允许重复,且插入和删除效率比用其他序列容器高。
map 可以自动建立 Key - value 的对应,key 和 value 可以是任意你需要的类型,根据 key 快速查找记录。
配接器和容器的(直接)增减
stack 首增首减 push() pop()
queue 首增尾减 push() pop()
vector 尾增尾减 push_back() pop_back()
deque 首尾都可增减 push_front() push_back() pop_front() pop_back()
各容器的共性
各容器一般来说都有下列函数:
默认构造函数、复制构造函数、析构函数、empty()、max_size()、size()、operator=、operator<、operator<=、operator>、operator>=、operator==、operator!=、swap()。
顺序容器和关联容器都共有下列函数
| 函数 | 作用 |
|---|
| begin() | 返回容器第一个元素的迭代器指针; | | end() | 返回容器最后一个元素后面一位的迭代器指针; | | rbegin() | 返回一个逆向迭代器指针,指向容器最后一个元素; | | rend() | 返回一个逆向迭代器指针,指向容器首个元素前面一位; | | clear() | 删除容器中的所有的元素; | | erase(it) | 删除迭代器指针it处元素。 |
array、vector 和 deque 容器的函数成员
| 函数成员 | 函数功能 | array<T,N> | vector | deque |
|---|
| begin() | 返回指向容器中第一个元素的迭代器。 | 是 | 是 | 是 | | end() | 返回指向容器最后一个元素所在位置后一个位置的迭代器,通常和 begin() 结合使用。 | 是 | 是 | 是 | | rbegin() | 返回指向最后一个元素的迭代器。 | 是 | 是 | 是 | | rend() | 返回指向第一个元素所在位置前一个位置的迭代器。 | 是 | 是 | 是 | | cbegin() | 和 begin() 功能相同,只不过在其基础上,增加了 const 属性,不能用于修改元素。 | 是 | 是 | 是 | | cend() | 和 end() 功能相同,只不过在其基础上,增加了 const 属性,不能用于修改元素。 | 是 | 是 | 是 | | crbegin() | 和 rbegin() 功能相同,只不过在其基础上,增加了 const 属性,不能用于修改元素。 | 是 | 是 | 是 | | crend() | 和 rend() 功能相同,只不过在其基础上,增加了 const 属性,不能用于修改元素。 | 是 | 是 | 是 | | assign() | 用新元素替换原有内容。 | - | 是 | 是 | | operator=() | 复制同类型容器的元素,或者用初始化列表替换现有内容。 | 是 | 是 | 是 | | size() | 返回实际元素个数。 | 是 | 是 | 是 | | max_size() | 返回元素个数的最大值。这通常是一个很大的值,一般是 232-1,所以我们很少会用到这个函数。 | 是 | 是 | 是 | | capacity() | 返回当前容量。 | - | 是 | - | | empty() | 判断容器中是否有元素,若无元素,则返回 true;反之,返回 false。 | 是 | 是 | 是 | | resize() | 改变实际元素的个数。 | - | 是 | 是 | | shrink _to_fit() | 将内存减少到等于当前元素实际所使用的大小。 | - | 是 | 是 | | front() | 返回第一个元素的引用。 | 是 | 是 | 是 | | back() | 返回最后一个元素的引用。 | 是 | 是 | 是 | | operator | 使用索引访问元素。 | 是 | 是 | 是 | | at() | 使用经过边界检査的索引访问元素。 | 是 | 是 | 是 | | push_back() | 在序列的尾部添加一个元素。 | - | 是 | 是 | | insert() | 在指定的位置插入一个或多个元素。 | - | 是 | 是 | | emplace() | 在指定的位置直接生成一个元素。 | - | 是 | 是 | | emplace_back() | 在序列尾部生成一个元素。 | - | 是 | 是 | | pop_back() | 移出序列尾部的元素。 | - | 是 | 是 | | erase() | 移出一个元素或一段元素。 | - | 是 | 是 | | clear() | 移出所有的元素,容器大小变为 0。 | - | 是 | 是 | | swap() | 交换两个容器的所有元素。 | 是 | 是 | 是 | | data() | 返回指向容器中第一个元素的指针。 | 是 | 是 | - |
list 和 forward_list 的函数成员
| 函数成员 | 函数功能 | list | forward_list |
|---|
| begin() | 返回指向容器中第一个元素的迭代器。 | 是 | 是 | | end() | 返回指向容器最后一个元素所在位置后一个位置的迭代器。 | 是 | 是 | | rbegin() | 返回指向最后一个元素的迭代器。 | 是 | - | | rend() | 返回指向第一个元素所在位置前一个位置的迭代器。 | 是 | - | | cbegin() | 和 begin() 功能相同,只不过在其基础上,增加了 const 属性,不能用于修改元素。 | 是 | 是 | | before_begin() | 返回指向第一个元素前一个位置的迭代器。 | - | 是 | | cbefore_begin() | 和 before_begin() 功能相同,只不过在其基础上,增加了 const 属性,即不能用该指针修改元素的值。 | - | 是 | | cend() | 和 end() 功能相同,只不过在其基础上,增加了 const 属性,不能用于修改元素。 | 是 | 是 | | crbegin() | 和 rbegin() 功能相同,只不过在其基础上,增加了 const 属性,不能用于修改元素。 | 是 | - | | crend() | 和 rend() 功能相同,只不过在其基础上,增加了 const 属性,不能用于修改元素。 | 是 | - | | assign() | 用新元素替换原有内容。 | 是 | 是 | | operator=() | 复制同类型容器的元素,或者用初始化列表替换现有内容。 | 是 | 是 | | size() | 返回实际元素个数。 | 是 | - | | max_size() | 返回元素个数的最大值,这通常是一个很大的值,一般是 232-1,所以我们很少会用到这个函数。 | 是 | 是 | | resize() | 改变实际元素的个数。 | 是 | 是 | | empty() | 判断容器中是否有元素,若无元素,则返回 true;反之,返回 false。 | 是 | 是 | | front() | 返回容器中第一个元素的引用。 | 是 | 是 | | back() | 返回容器中最后一个元素的引用。 | 是 | - | | push_back() | 在序列的尾部添加一个元素。 | 是 | - | | push_front() | 在序列的起始位置添加一个元素。 | 是 | 是 | | emplace() | 在指定位置直接生成一个元素。 | 是 | - | | emplace_after() | 在指定位置的后面直接生成一个元素。 | - | 是 | | emplace_back() | 在序列尾部生成一个元素。 | 是 | - | | cmplacc_front() | 在序列的起始位生成一个元索。 | 是 | 是 | | insert() | 在指定的位置插入一个或多个元素。 | 是 | - | | insert_after() | 在指定位置的后面插入一个或多个元素。 | - | 是 | | pop_back() | 移除序列尾部的元素。 | 是 | - | | pop_front() | 移除序列头部的元素。 | 是 | 是 | | reverse() | 反转容器中某一段的元素。 | 是 | 是 | | erase() | 移除指定位置的一个元素或一段元素。 | 是 | - | | erase_after() | 移除指定位置后面的一个元素或一段元素。 | - | 是 | | remove() | 移除所有和参数匹配的元素。 | 是 | 是 | | remove_if() | 移除满足一元函数条件的所有元素。 | 是 | 是 | | unique() | 移除所有连续重复的元素。 | 是 | 是 | | clear() | 移除所有的元素,容器大小变为 0。 | 是 | 是 | | swap() | 交换两个容器的所有元素。 | 是 | 是 | | sort() | 对元素进行排序。 | 是 | 是 | | merge() | 合并两个有序容器。 | 是 | 是 | | splice() | 移动指定位置前面的所有元素到另一个同类型的 list 中。 | 是 | - | | splice_after() | 移动指定位置后面的所有元素到另一个同类型的 list 中。 | - | 是 |
■ 迭代器
各容器的迭代器
| 容器 | 迭代器功能 |
|---|
| vector | 随机访问 | | deque | 随机访问 | | list | 双向 | | set / multiset | 双向 | | map / multimap | 双向 | | stack | 不支持迭代器 | | queue | 不支持迭代器 | | priority_queue | 不支持迭代器 |
(1)所有迭代器
| 迭代器操作 | 操作含义 |
|---|
| p++ | 后置自增迭代器 | | ++p | 前置自增迭代器 |
(2)输入迭代器
| 迭代器操作 | 操作含义 |
|---|
| *p | 复引用迭代器,作为右值 | | p=p1 | 将一个迭代器赋给另一个迭代器 | | p==p1 | 比较迭代器的相等性 | | p!=p1 | 比较迭代器的不等性 |
(3)输出迭代器
| 迭代器操作 | 操作含义 |
|---|
| *p | 复引用迭代器,作为左值 | | p=p1 | 将一个迭代器赋给另一个迭代器 |
(4)正向迭代器
? 提供输入输出迭代器的所有功能
(5)双向迭代器
| 迭代器操作 | 操作含义 |
|---|
| –p | 前置自减迭代器 | | p– | 后置自减迭代器 |
(6)随机迭代器
| 迭代器操作 | 操作含义 |
|---|
| p+=i | 将迭代器递增i位 | | p-=i | 将迭代器递减i位 | | p+i | 在p位加i位后的迭代器 | | p-i | 在p位减i位后的迭代器 | | p[i] | 返回p位元素偏离i位的元素引用 | | p<p1 | 如果迭代器p的位置在p1前,返回true,否则返回false | | p<=p1 | p的位置在p1的前面或同一位置时返回true,否则返回false | | p>p1 | 如果迭代器p的位置在p1后,返回true,否则返回false | | p>=p1 | p的位置在p1的后面或同一位置时返回true,否则返回false |
|