2018-06-05 00:26:27 +08:00
|
|
|
|
[STL 详细文档](https://github.com/huihut/interview/blob/master/STL/STL.md)
|
|
|
|
|
|
2018-06-04 23:38:38 +08:00
|
|
|
|
# 容器(containers)
|
|
|
|
|
|
|
|
|
|
## array
|
|
|
|
|
|
|
|
|
|
array 是固定大小的顺序容器,它们保存了一个以严格的线性顺序排列的特定数量的元素。
|
|
|
|
|
|
|
|
|
|
方法|含义
|
|
|
|
|
---|---
|
|
|
|
|
begin|返回指向数组容器中第一个元素的迭代器
|
|
|
|
|
end|返回指向数组容器中最后一个元素之后的理论元素的迭代器
|
|
|
|
|
rbegin|返回指向数组容器中最后一个元素的反向迭代器
|
|
|
|
|
rend|返回一个反向迭代器,指向数组中第一个元素之前的理论元素
|
|
|
|
|
cbegin|返回指向数组容器中第一个元素的常量迭代器(const_iterator)
|
|
|
|
|
cend|返回指向数组容器中最后一个元素之后的理论元素的常量迭代器(const_iterator)
|
|
|
|
|
crbegin|返回指向数组容器中最后一个元素的常量反向迭代器(const_reverse_iterator)
|
|
|
|
|
crend|返回指向数组中第一个元素之前的理论元素的常量反向迭代器(const_reverse_iterator)
|
|
|
|
|
size|返回数组容器中元素的数量
|
|
|
|
|
max_size|返回数组容器可容纳的最大元素数
|
|
|
|
|
empty|返回一个布尔值,指示数组容器是否为空
|
2018-06-13 11:49:12 +08:00
|
|
|
|
operator[]|返回容器中第 n(参数)个位置的元素的引用
|
|
|
|
|
at|返回容器中第 n(参数)个位置的元素的引用
|
2018-06-04 23:38:38 +08:00
|
|
|
|
front|返回对容器中第一个元素的引用
|
|
|
|
|
back|返回对容器中最后一个元素的引用
|
|
|
|
|
data|返回指向容器中第一个元素的指针
|
|
|
|
|
fill|用 val(参数)填充数组所有元素
|
|
|
|
|
swap|通过 x(参数)的内容交换数组的内容
|
|
|
|
|
get(array)|形如 `std::get<0>(myarray)`;传入一个数组容器,返回指定位置元素的引用
|
|
|
|
|
relational operators (array)|形如 `arrayA > arrayB`;依此比较数组每个元素的大小关系
|
|
|
|
|
|
|
|
|
|
## vector
|
|
|
|
|
|
|
|
|
|
vector 是表示可以改变大小的数组的序列容器。
|
|
|
|
|
|
|
|
|
|
方法|含义
|
|
|
|
|
---|---
|
|
|
|
|
vector|构造函数
|
|
|
|
|
~vector|析构函数,销毁容器对象
|
|
|
|
|
operator=|将新内容分配给容器,替换其当前内容,并相应地修改其大小
|
2018-06-07 14:20:52 +08:00
|
|
|
|
begin|返回指向容器中第一个元素的迭代器
|
|
|
|
|
end|返回指向容器中最后一个元素之后的理论元素的迭代器
|
|
|
|
|
rbegin|返回指向容器中最后一个元素的反向迭代器
|
|
|
|
|
rend|返回一个反向迭代器,指向中第一个元素之前的理论元素
|
|
|
|
|
cbegin|返回指向容器中第一个元素的常量迭代器(const_iterator)
|
|
|
|
|
cend|返回指向容器中最后一个元素之后的理论元素的常量迭代器(const_iterator)
|
|
|
|
|
crbegin|返回指向容器中最后一个元素的常量反向迭代器(const_reverse_iterator)
|
|
|
|
|
crend|返回指向容器中第一个元素之前的理论元素的常量反向迭代器(const_reverse_iterator)
|
|
|
|
|
size|返回容器中元素的数量
|
|
|
|
|
max_size|返回容器可容纳的最大元素数
|
2018-06-04 23:38:38 +08:00
|
|
|
|
resize|调整容器的大小,使其包含 n(参数)个元素
|
|
|
|
|
capacity|返回当前为 vector 分配的存储空间(容量)的大小
|
|
|
|
|
empty|返回 vector 是否为空
|
2018-06-13 11:49:12 +08:00
|
|
|
|
reserve|请求 vector 容量至少足以包含 n(参数)个元素
|
2018-06-04 23:38:38 +08:00
|
|
|
|
shrink_to_fit|要求容器减小其 capacity(容量)以适应其 size(元素数量)
|
2018-06-13 11:49:12 +08:00
|
|
|
|
operator[]|返回容器中第 n(参数)个位置的元素的引用
|
|
|
|
|
at|返回中第 n(参数)个位置的元素的引用
|
2018-06-04 23:38:38 +08:00
|
|
|
|
front|返回对容器中第一个元素的引用
|
|
|
|
|
back|返回对容器中最后一个元素的引用
|
|
|
|
|
data|返回指向容器中第一个元素的指针
|
|
|
|
|
assign|将新内容分配给 vector,替换其当前内容,并相应地修改其 size
|
|
|
|
|
push_back|在容器的最后一个元素之后添加一个新元素
|
|
|
|
|
pop_back|删除容器中的最后一个元素,有效地将容器 size 减少一个
|
|
|
|
|
insert|通过在指定位置的元素之前插入新元素来扩展该容器,通过插入元素的数量有效地增加容器大小
|
|
|
|
|
erase|从 vector 中删除单个元素(`position`)或一系列元素(`[first,last)`),这有效地减少了被去除的元素的数量,从而破坏了容器的大小
|
|
|
|
|
swap|通过 x(参数)的内容交换容器的内容,x 是另一个类型相同、size 可能不同的 vector 对象
|
|
|
|
|
clear|从 vector 中删除所有的元素(被销毁),留下 size 为 0 的容器
|
|
|
|
|
emplace|通过在 position(参数)位置处插入新元素 args(参数)来扩展容器
|
|
|
|
|
emplace_back|在 vector 的末尾插入一个新的元素,紧跟在当前的最后一个元素之后
|
|
|
|
|
get_allocator|返回与vector关联的构造器对象的副本
|
|
|
|
|
swap(vector)|容器 x(参数)的内容与容器 y(参数)的内容交换。两个容器对象都必须是相同的类型(相同的模板参数),尽管大小可能不同
|
2018-06-07 14:20:52 +08:00
|
|
|
|
relational operators (vector)|形如 `vectorA > vectorB`;依此比较每个元素的大小关系
|
2018-06-04 23:38:38 +08:00
|
|
|
|
|
|
|
|
|
## deque
|
|
|
|
|
|
|
|
|
|
deque(['dek])(双端队列)是double-ended queue 的一个不规则缩写。deque是具有动态大小的序列容器,可以在两端(前端或后端)扩展或收缩。
|
|
|
|
|
|
|
|
|
|
方法|含义
|
|
|
|
|
---|---
|
|
|
|
|
deque|构造函数
|
|
|
|
|
push_back|在当前的最后一个元素之后 ,在 deque 容器的末尾添加一个新元素
|
|
|
|
|
push_front|在 deque 容器的开始位置插入一个新的元素,位于当前的第一个元素之前
|
|
|
|
|
pop_back|删除 deque 容器中的最后一个元素,有效地将容器大小减少一个
|
|
|
|
|
pop_front|删除 deque 容器中的第一个元素,有效地减小其大小
|
|
|
|
|
emplace_front|在 deque 的开头插入一个新的元素,就在其当前的第一个元素之前
|
|
|
|
|
emplace_back|在 deque 的末尾插入一个新的元素,紧跟在当前的最后一个元素之后
|
|
|
|
|
|
|
|
|
|
## forward\_list
|
|
|
|
|
|
|
|
|
|
forward_list(单向链表)是序列容器,允许在序列中的任何地方进行恒定的时间插入和擦除操作。
|
|
|
|
|
|
|
|
|
|
方法|含义
|
|
|
|
|
---|---
|
|
|
|
|
forward\_list|返回指向容器中第一个元素之前的位置的迭代器
|
|
|
|
|
cbefore\_begin|返回指向容器中第一个元素之前的位置的 const_iterator
|
|
|
|
|
|
|
|
|
|
## list
|
|
|
|
|
|
|
|
|
|
list,双向链表,是序列容器,允许在序列中的任何地方进行常数时间插入和擦除操作,并在两个方向上进行迭代。
|
|
|
|
|
|
|
|
|
|
## stack
|
|
|
|
|
|
|
|
|
|
stack 是一种容器适配器,用于在LIFO(后进先出)的操作,其中元素仅从容器的一端插入和提取。
|
|
|
|
|
|
|
|
|
|
## queue
|
|
|
|
|
|
|
|
|
|
queue 是一种容器适配器,用于在FIFO(先入先出)的操作,其中元素插入到容器的一端并从另一端提取。
|
|
|
|
|
|
|
|
|
|
## priority_queue
|
|
|
|
|
|
|
|
|
|
## set
|
|
|
|
|
|
|
|
|
|
set 是按照特定顺序存储唯一元素的容器。
|
|
|
|
|
|
|
|
|
|
## multiset
|
|
|
|
|
|
|
|
|
|
## map
|
|
|
|
|
|
|
|
|
|
map 是关联容器,按照特定顺序存储由 key value (键值) 和 mapped value (映射值) 组合形成的元素。
|
|
|
|
|
|
|
|
|
|
方法|含义
|
|
|
|
|
---|---
|
|
|
|
|
map|构造函数
|
|
|
|
|
begin|返回引用容器中第一个元素的迭代器
|
|
|
|
|
key_comp|返回容器用于比较键的比较对象的副本
|
|
|
|
|
value_comp|返回可用于比较两个元素的比较对象,以获取第一个元素的键是否在第二个元素之前
|
|
|
|
|
find|在容器中搜索具有等于 k(参数)的键的元素,如果找到则返回一个迭代器,否则返回 map::end 的迭代器
|
|
|
|
|
count|在容器中搜索具有等于 k(参数)的键的元素,并返回匹配的数量
|
2018-06-07 20:15:11 +08:00
|
|
|
|
lower_bound|返回一个非递减序列 `[first, last)`(参数)中的第一个大于等于值 val(参数)的位置的迭代器
|
|
|
|
|
upper_bound|返回一个非递减序列 `[first, last)`(参数)中第一个大于 val(参数)的位置的迭代器
|
2018-06-04 23:38:38 +08:00
|
|
|
|
equal_range|获取相同元素的范围,返回包含容器中所有具有与 k(参数)等价的键的元素的范围边界(`pair< map<char,int>::iterator, map<char,int>::iterator >`)
|
|
|
|
|
|
|
|
|
|
## multimap
|
|
|
|
|
|
|
|
|
|
## unordered\_set
|
|
|
|
|
|
|
|
|
|
## unordered\_multiset
|
|
|
|
|
|
|
|
|
|
## unordered\_map
|
|
|
|
|
|
|
|
|
|
## unordered\_multimap
|
|
|
|
|
|
|
|
|
|
## tuple
|
|
|
|
|
|
|
|
|
|
元组是一个能够容纳元素集合的对象。每个元素可以是不同的类型。
|
|
|
|
|
|
|
|
|
|
## pair
|
|
|
|
|
|
|
|
|
|
这个类把一对值(values)结合在一起,这些值可能是不同的类型(T1 和 T2)。每个值可以被公有的成员变量first、second访问。
|
2018-06-05 12:52:32 +08:00
|
|
|
|
|
|
|
|
|
# 算法(algorithms)
|
|
|
|
|
|
|
|
|
|
方法|含义
|
|
|
|
|
---|---
|
|
|
|
|
all_of|返回容器范围 `[first,last)`(参数,迭代器(下同))内的所有元素是否都满足 pred(参数,如 `[](int i){return i%2;}`(下同))条件的布尔值
|
|
|
|
|
any_of|返回容器范围 `[first,last)`(参数)内的任何元素是否存在满足 pred(参数)条件的布尔值
|
|
|
|
|
none_of|返回容器范围 `[first,last)`(参数)内的所以元素是否都不满足 pred(参数)条件的布尔值
|
|
|
|
|
for_each|对于容器范围 `[first,last)`(参数)内的所以元素都调用 fn(参数,一元函数的指针或函数对象)
|
|
|
|
|
find|返回容器范围 `[first,last)`(参数)第一个等于 val(参数)的迭代器。如果没有找到这样的元素则返回 last(参数)
|
|
|
|
|
find_if|返回容器范围 `[first,last)`(参数)内的第一个 pred(参数,一元布尔函数指针)为 true 的迭代器
|
|
|
|
|
find_if_not|返回容器范围 `[first,last)`(参数)内的第一个 pred(参数,一元布尔函数指针)为 false 的迭代器
|
2018-06-07 14:20:52 +08:00
|
|
|
|
find_end|返回容器范围 `[first1,last1)`(参数)内的最后一个完全匹配 `[first2,last2)`(参数)的 `first2`(参数)的迭代器,无法找到则返回 `last1`(参数)
|
|
|
|
|
count|返回容器范围 `[first1,last1)`(参数)内等于 val(参数)的元素个数
|
|
|
|
|
equal|返回容器范围 `[first1,last1)`(参数)与 `first2`开始的容器是否全部元素相等的布尔值
|
|
|
|
|
search|返回容器范围 `[first1,last1)`(参数)内的第一个完全匹配 `[first2,last2)`(参数)的 `first2`(参数)的迭代器,无法找到则返回 `last1`(参数)
|
|
|
|
|
copy|将范围 `[first1,last1)`(参数)内的元素复制到从 `result`(参数)迭代器开始的容器,返回 `result`(参数)指向的容器的范围 `[first1,last1)`(参数)的末尾
|
|
|
|
|
move|将范围 `[first1,last1)`(参数)内的元素移动到从 `result`(参数)迭代器开始的容器,返回 `result`(参数)指向的容器的范围 `[first1,last1)`(参数)的末尾
|
2018-06-20 18:28:32 +08:00
|
|
|
|
swap|交换 `a`、`b`(参数)两个对象的值
|
|
|
|
|
|
|
|
|
|
```cpp
|
2018-06-21 11:11:45 +08:00
|
|
|
|
// 简单查找算法,要求输入迭代器(input iterator)
|
2018-06-21 09:33:15 +08:00
|
|
|
|
find(beg, end, val); // 返回一个迭代器,指向输入序列中第一个等于 val 的元素,未找到返回 end
|
|
|
|
|
find_if(beg, end, unaryPred); // 返回一个迭代器,指向第一个满足 unaryPred 的元素,未找到返回 end
|
|
|
|
|
find_if_not(beg, end, unaryPred); // 返回一个迭代器,指向第一个令 unaryPred 为 false 的元素,未找到返回 end
|
|
|
|
|
count(beg, end, val); // 返回一个计数器,指出 val 出现了多少次
|
|
|
|
|
count_if(beg, end, unaryPred); // 统计有多少个元素满足 unaryPred
|
|
|
|
|
all_of(beg, end, unaryPred); // 返回一个 bool 值,判断是否所有元素都满足 unaryPred
|
|
|
|
|
any_of(beg, end, unaryPred); // 返回一个 bool 值,判断是否任意(存在)一个元素满足 unaryPred
|
|
|
|
|
none_of(beg, end, unaryPred); // 返回一个 bool 值,判断是否所有元素都不满足 unaryPred
|
2018-06-20 18:28:32 +08:00
|
|
|
|
|
2018-06-21 11:11:45 +08:00
|
|
|
|
// 查找重复值的算法,传入向前迭代器(forward iterator)
|
|
|
|
|
adjacent_find(beg, end); // 返回指向第一对相邻重复元素的迭代器,无相邻元素则返回 end
|
|
|
|
|
adjacent_find(beg, end, binaryPred); // 返回指向第一对相邻重复元素的迭代器,无相邻元素则返回 end
|
|
|
|
|
search_n(beg, end, count, val); // 返回一个迭代器,从此位置开始有 count 个相等元素,不存在则返回 end
|
|
|
|
|
search_n(beg, end, count, val, binaryPred); // 返回一个迭代器,从此位置开始有 count 个相等元素,不存在则返回 end
|
|
|
|
|
|
|
|
|
|
// 查找子序列算法,除 find_first_of(前两个输入迭代器,后两个前向迭代器) 外,都要求两个前向迭代器
|
|
|
|
|
search(beg1, end1, beg2, end2); // 返回第二个输入范围(子序列)在爹一个输入范围中第一次出现的位置,未找到则返回 end1
|
|
|
|
|
search(beg1, end1, beg2, end2, binaryPred); // 返回第二个输入范围(子序列)在爹一个输入范围中第一次出现的位置,未找到则返回 end1
|
|
|
|
|
find_first_of(beg1, end1, beg2, end2); // 返回一个迭代器,指向第二个输入范围中任意元素在第一个范围中首次出现的位置,未找到则返回end1
|
|
|
|
|
find_first_of(beg1, end1, beg2, end2, binaryPred); // 返回一个迭代器,指向第二个输入范围中任意元素在第一个范围中首次出现的位置,未找到则返回end1
|
|
|
|
|
find_end(beg1, end1, beg2, end2); // 类似 search,但返回的最后一次出现的位置。如果第二个输入范围为空,或者在第一个输入范围为空,或者在第一个输入范围中未找到它,则返回 end1
|
|
|
|
|
find_end(beg1, end1, beg2, end2, binaryPred); // 类似 search,但返回的最后一次出现的位置。如果第二个输入范围为空,或者在第一个输入范围为空,或者在第一个输入范围中未找到它,则返回 end1
|
|
|
|
|
|
|
|
|
|
// 其他只读算法,传入输入迭代器
|
|
|
|
|
for_each(beg, end, unaryOp); // 对输入序列中的每个元素应用可调用对象 unaryOp,unaryOp 的返回值被忽略
|
|
|
|
|
mismatch(beg1, end1, beg2); // 比较两个序列中的元素。返回一个迭代器的 pair,表示两个序列中第一个不匹配的元素
|
|
|
|
|
mismatch(beg1, end1, beg2, binaryPred); // 比较两个序列中的元素。返回一个迭代器的 pair,表示两个序列中第一个不匹配的元素
|
|
|
|
|
equal(beg1, end1, beg2); // 比较每个元素,确定两个序列是否相等。
|
|
|
|
|
equal(beg1, end1, beg2, binaryPred); // 比较每个元素,确定两个序列是否相等。
|
|
|
|
|
|
|
|
|
|
// 二分搜索算法,传入前向迭代器或随机访问迭代器(random-access iterator),要求序列中的元素已经是有序的。通过小于运算符(<)或 comp 比较操作实现比较。
|
|
|
|
|
lower_bound(beg, end, val); // 返回一个迭代器,表示第一个小于等于 val 的元素,不存在则返回 end
|
|
|
|
|
lower_bound(beg, end, val, comp); // 返回一个迭代器,表示第一个小于等于 val 的元素,不存在则返回 end
|
|
|
|
|
upper_bound(beg, end, val); // 返回一个迭代器,表示第一个大于 val 的元素,不存在则返回 end
|
|
|
|
|
upper_bound(beg, end, val, comp); // 返回一个迭代器,表示第一个大于 val 的元素,不存在则返回 end
|
|
|
|
|
equal_range(beg, end, val); // 返回一个 pair,其 first 成员是 lower_bound 返回的迭代器,其 second 成员是 upper_bound 返回的迭代器
|
|
|
|
|
binary_search(beg, end, val); // 返回一个 bool 值,指出序列中是否包含等于 val 的元素。对于两个值 x 和 y,当 x 不小于 y 且 y 也不小于 x 时,认为它们相等。
|
|
|
|
|
|
|
|
|
|
// 只写不读算法,要求输出迭代器(output iterator)
|
|
|
|
|
fill(beg, end, val); // 将 val 赋予每个元素,返回 void
|
|
|
|
|
fill_n(beg, cnt, val); // 将 val 赋予 cnt 个元素,返回指向写入到输出序列最有一个元素之后位置的迭代器
|
|
|
|
|
genetate(beg, end, Gen); // 每次调用 Gen() 生成不同的值赋予每个序列,返回 void
|
|
|
|
|
genetate_n(beg, cnt, Gen); // 每次调用 Gen() 生成不同的值赋予 cnt 个序列,返回指向写入到输出序列最有一个元素之后位置的迭代器
|
|
|
|
|
|
|
|
|
|
// 使用输入迭代器的写算法,读取一个输入序列,将值写入到一个输出序列(dest)中
|
|
|
|
|
copy(beg, end, dest); // 从输入范围将元素拷贝所有元素到 dest 指定定的目的序列
|
|
|
|
|
copy_if(beg, end, dest, unaryPred); // 从输入范围将元素拷贝满足 unaryPred 的元素到 dest 指定定的目的序列
|
|
|
|
|
copy_n(beg, n, dest); // 从输入范围将元素拷贝前 n 个元素到 dest 指定定的目的序列
|
|
|
|
|
move(beg, end, dest); // 对输入序列中的每个元素调用 std::move,将其移动到迭代器 dest 开始始的序列中
|
|
|
|
|
transform(beg, end, dest, unaryOp); // 调用给定操作(一元操作),并将结果写到dest中
|
|
|
|
|
transform(beg, end, beg2, dest, binaryOp); // 调用给定操作(二元操作),并将结果写到dest中
|
|
|
|
|
replace_copy(beg, end, dest, old_val, new_val); // 将每个元素拷贝到 dest,将等于 old_val 的的元素替换为 new_val
|
|
|
|
|
replace_copy_if(beg, end, dest, unaryPred, new_val); // 将每个元素拷贝到 dest,将满足 unaryPred 的的元素替换为 new_val
|
|
|
|
|
merge(beg1, end1, beg2, end2, dest); // 两个输入序列必须都是有序的,用 < 运算符将合并后的序列写入到 dest 中
|
|
|
|
|
merge(beg1, end1, beg2, end2, dest, comp) // 两个输入序列必须都是有序的,使用给定的比较操作(comp)将合并后的序列写入到 dest 中
|
|
|
|
|
|
2018-06-20 18:28:32 +08:00
|
|
|
|
```
|