算法库
来自cppreference.com
< cpp
算法库提供大量用途的函数(例如查找、排序、计数、操作),它们在元素范围上操作。注意范围定义为 [first, last)
,其中 last
指代要查询或修改的最后元素的后一个元素。
受约束算法C++20 在命名空间 std::vector<int> v = {7, 1, 4, 0, -1}; std::ranges::sort(v); // 受约束算法 |
(C++20 起) |
执行策略大多数算法拥有接受执行策略的重载。标准算法库提供几种执行策略,并提供对应执行策略的类型和对象。用户可以静态地选择执行策略,通过以对应类型的执行策略对象为参数,调用并行算法。 标准库实现(但不是用户)可以定义附加的执行策略作为扩展。以实现定义类型的执行策略对象调用的并行算法的语义是实现定义的。 允许算法的并行版本(除了 std::for_each 与 std::for_each_n )从范围进行任意的元素复制,只要 std::is_trivially_copy_constructible_v<T> 与 std::is_trivially_destructible_v<T> 均为 true ,其中
|
(C++17 起) |
不修改序列的操作 | |
在标头
<algorithm> 定义 | |
(C++11)(C++11)(C++11) |
检查谓词是否对范围中所有、任一或无元素为 true (函数模板) |
(C++20)(C++20)(C++20) |
检查谓词是否对范围中所有、任一或无元素为 true (niebloid) |
应用函数到范围中的元素 (函数模板) | |
(C++20) |
应用函数到范围中的元素 (niebloid) |
(C++17) |
应用一个函数对象到序列的前 n 个元素 (函数模板) |
(C++20) |
应用函数对象到序列的首 n 个元素 (niebloid) |
返回满足指定判别标准的元素数 (函数模板) | |
(C++20)(C++20) |
返回满足指定判别标准的元素数 (niebloid) |
寻找两个范围出现不同的首个位置 (函数模板) | |
(C++20) |
寻找两个范围出现不同的首个位置 (niebloid) |
(C++11) |
寻找首个满足特定判别标准的元素 (函数模板) |
(C++20)(C++20)(C++20) |
查找满足特定条件的的第一个元素 (niebloid) |
在特定范围中寻找最后出现的元素序列 (函数模板) | |
(C++20) |
查找特定范围中最后出现的元素序列 (niebloid) |
搜索元素集合中的任意元素 (函数模板) | |
(C++20) |
查找元素集合中的任一元素 (niebloid) |
查找首对相邻的相同(或满足给定谓词的)元素 (函数模板) | |
(C++20) |
查找首对相邻的相同(或满足给定谓词的)元素 (niebloid) |
搜索一个元素范围 (函数模板) | |
(C++20) |
搜索一个元素范围 (niebloid) |
在范围中搜索一定量的某个元素的连续副本 (函数模板) | |
(C++20) |
在范围中搜索一定量的某个元素的连续副本 (niebloid) |
(C++23) |
检查一个范围是否始于另一范围 (niebloid) |
(C++23) |
检查一个范围是否终于另一范围 (niebloid) |
修改序列的操作 | |
在标头
<algorithm> 定义 | |
(C++11) |
将某一范围的元素复制到一个新的位置 (函数模板) |
(C++20)(C++20) |
将某一范围的元素复制到一个新的位置 (niebloid) |
(C++11) |
将一定数目的元素复制到一个新的位置 (函数模板) |
(C++20) |
将一定数目的元素复制到一个新的位置 (niebloid) |
按从后往前的顺序复制一个范围内的元素 (函数模板) | |
(C++20) |
按从后往前的顺序复制一个范围内的元素 (niebloid) |
(C++11) |
将某一范围的元素移动到一个新的位置 (函数模板) |
(C++20) |
将某一范围的元素移动到一个新的位置 (niebloid) |
(C++11) |
按从后往前的顺序移动某一范围的元素到新的位置 (函数模板) |
(C++20) |
按从后往前的顺序移动某一范围的元素到新的位置 (niebloid) |
将一个给定值复制赋值给一个范围内的每个元素 (函数模板) | |
(C++20) |
将一个给定值复制赋值给一个范围内的每个元素 (niebloid) |
将一个给定值复制赋值给一个范围内的 N 个元素 (函数模板) | |
(C++20) |
将一个值复制赋值给一定量的元素 (niebloid) |
将一个函数应用于某一范围的各个元素,并在目标范围存储结果 (函数模板) | |
(C++20) |
将一个函数应用于某一范围的各个元素 (niebloid) |
将相继的函数调用结果赋值给一个范围中的每个元素 (函数模板) | |
(C++20) |
保存函数结果到一个范围中 (niebloid) |
将相继的函数调用结果赋值给一个范围中的 N 个元素 (函数模板) | |
(C++20) |
保存 N 次函数应用的结果 (niebloid) |
移除满足特定判别标准的元素 (函数模板) | |
(C++20)(C++20) |
移除满足特定判别标准的元素 (niebloid) |
复制一个范围的元素,忽略满足特定判别标准的元素 (函数模板) | |
(C++20)(C++20) |
复制一个范围的元素,忽略满足特定判别标准的元素 (niebloid) |
将所有满足特定判别标准的值替换为另一个值 (函数模板) | |
(C++20)(C++20) |
将所有满足特定判别标准的值替换为另一个值 (niebloid) |
复制一个范围内的元素,并将满足特定判别标准的元素替换为另一个值 (函数模板) | |
(C++20)(C++20) |
复制一个范围内的元素,并将满足特定判别标准的元素替换为另一个值 (niebloid) |
交换两个对象的值 (函数模板) | |
交换两个范围的元素 (函数模板) | |
(C++20) |
交换两个范围的元素 (niebloid) |
交换两个迭代器所指向的元素 (函数模板) | |
逆转范围中的元素顺序 (函数模板) | |
(C++20) |
逆转范围中的元素顺序 (niebloid) |
创建一个范围的逆向副本 (函数模板) | |
(C++20) |
创建一个范围的逆向副本 (niebloid) |
旋转范围中的元素顺序 (函数模板) | |
(C++20) |
旋转范围中的元素顺序 (niebloid) |
复制并旋转元素范围 (函数模板) | |
(C++20) |
复制并旋转元素范围 (niebloid) |
(C++20) |
迁移范围中的元素 (函数模板) |
迁移范围中的元素 (niebloid) | |
(C++17 前)(C++11) |
随机重排范围中的元素 (函数模板) |
(C++20) |
随机重排范围中的元素 (niebloid) |
(C++17) |
从一个序列中随机选择 n 个元素 (函数模板) |
(C++20) |
从序列中随机选择 n 个元素 (niebloid) |
移除范围内的连续重复元素 (函数模板) | |
(C++20) |
移除范围中的连续重复元素 (niebloid) |
创建某范围的不含连续重复元素的副本 (函数模板) | |
(C++20) |
创建某范围的不含连续重复元素的副本 (niebloid) |
划分操作 | |
在标头
<algorithm> 定义 | |
(C++11) |
判断范围是否已按给定的谓词划分 (函数模板) |
(C++20) |
判断范围是否已按给定的谓词划分 (niebloid) |
将范围中的元素分为两组 (函数模板) | |
(C++20) |
将范围中的元素分为二组 (niebloid) |
(C++11) |
复制一个范围,将各元素分为两组 (函数模板) |
(C++20) |
复制一个范围,将各元素分为二组 (niebloid) |
将元素分为两组,同时保留其相对顺序 (函数模板) | |
(C++20) |
将元素分成二组,同时保持其相对顺序 (niebloid) |
(C++11) |
定位已划分范围的划分点 (函数模板) |
(C++20) |
定位已划分范围的划分点 (niebloid) |
排序操作 | |
在标头
<algorithm> 定义 | |
(C++11) |
检查范围是否已按升序排列 (函数模板) |
(C++20) |
检查范围是否以升序排序 (niebloid) |
(C++11) |
找出最大的已排序子范围 (函数模板) |
(C++20) |
寻找最大的已排序子范围 (niebloid) |
将范围按升序排序 (函数模板) | |
(C++20) |
将范围按升序排序 (niebloid) |
排序一个范围的前 N 个元素 (函数模板) | |
(C++20) |
排序一个范围的前 N 个元素 (niebloid) |
对范围内的元素进行复制并部分排序 (函数模板) | |
(C++20) |
对范围内的元素进行复制并部分排序 (niebloid) |
将范围内的元素排序,同时保持相等的元素之间的顺序 (函数模板) | |
(C++20) |
将范围内的元素排序,同时保持相等的元素之间的顺序 (niebloid) |
将给定的范围部分排序,确保其按给定元素划分 (函数模板) | |
(C++20) |
将给定的范围部分排序,确保其按给定元素划分 (niebloid) |
二分搜索操作(在已排序范围上) | |
在标头
<algorithm> 定义 | |
返回指向第一个不小于给定值的元素的迭代器 (函数模板) | |
(C++20) |
返回指向首个不小于给定值的元素的迭代器 (niebloid) |
返回指向第一个大于给定值的元素的迭代器 (函数模板) | |
(C++20) |
返回指向首个大于某值的元素的迭代器 (niebloid) |
确定元素是否存在于某范围中 (函数模板) | |
(C++20) |
确定元素是否存在于某范围中 (niebloid) |
返回匹配特定键值的元素范围 (函数模板) | |
(C++20) |
返回匹配特定值的元素范围 (niebloid) |
其他已排序范围上的操作 | |
在标头
<algorithm> 定义 | |
归并两个有序范围 (函数模板) | |
(C++20) |
归并两个有序范围 (niebloid) |
就地归并两个有序范围 (函数模板) | |
(C++20) |
在原位归并两个有序范围 (niebloid) |
集合操作(在已排序范围上) | |
在标头
<algorithm> 定义 | |
若一个序列是另一个的子列则返回 true (函数模板) | |
(C++20) |
若一个序列是另一个的子列则返回 true (niebloid) |
计算两个集合的差集 (函数模板) | |
(C++20) |
计算两个集合的差集 (niebloid) |
计算两个集合的交集 (函数模板) | |
(C++20) |
计算两个集合的交集 (niebloid) |
计算两个集合的对称差 (函数模板) | |
计算两个集合的对称差 (niebloid) | |
计算两个集合的并集 (函数模板) | |
(C++20) |
计算两个集合的并集 (niebloid) |
堆操作 | |
在标头
<algorithm> 定义 | |
检查给定范围是否为一个最大堆 (函数模板) | |
(C++20) |
检查给定范围是否为最大堆 (niebloid) |
(C++11) |
查找能成为最大堆的最大子范围 (函数模板) |
(C++20) |
寻找能成为最大堆的最大子范围 (niebloid) |
从一个元素范围创建出一个最大堆 (函数模板) | |
(C++20) |
从一个元素范围创建出一个最大堆 (niebloid) |
将一个元素加入到一个最大堆 (函数模板) | |
(C++20) |
将一个元素加入到一个最大堆 (niebloid) |
从最大堆中移除最大元素 (函数模板) | |
(C++20) |
从最大堆中移除最大元素 (niebloid) |
将一个最大堆变成一个按升序排序的元素范围 (函数模板) | |
(C++20) |
将一个最大堆变成一个按升序排序的元素范围 (niebloid) |
最小/最大操作 | |
在标头
<algorithm> 定义 | |
返回各给定值中的较大者 (函数模板) | |
(C++20) |
返回给定值的较大者 (niebloid) |
返回范围内的最大元素 (函数模板) | |
(C++20) |
返回范围中的最大元素 (niebloid) |
返回各给定值中的较小者 (函数模板) | |
(C++20) |
返回给定值的较小者 (niebloid) |
返回范围内的最小元素 (函数模板) | |
(C++20) |
返回范围中的最小元素 (niebloid) |
(C++11) |
返回两个元素的较小和较大者 (函数模板) |
(C++20) |
返回两个元素的较小和较大者 (niebloid) |
(C++11) |
返回范围内的最小元素和最大元素 (函数模板) |
(C++20) |
返回范围中的最小和最大元素 (niebloid) |
(C++17) |
在一对边界值间夹逼一个值 (函数模板) |
(C++20) |
在一对边界值间夹一个值 (niebloid) |
比较操作 | |
在标头
<algorithm> 定义 | |
确定两个元素集合是否是相同的 (函数模板) | |
(C++20) |
确定两个元素集合是否是相同的 (niebloid) |
当一个范围按字典顺序小于另一个范围时,返回 true (函数模板) | |
当一个范围按字典顺序小于另一个范围时,返回 true (niebloid) | |
用三路比较比较两个范围 (函数模板) | |
排列操作 | |
在标头
<algorithm> 定义 | |
(C++11) |
判断一个序列是否为另一个序列的排列 (函数模板) |
(C++20) |
确定一个序列是否为另一序列的重排 (niebloid) |
产生某个元素范围的按字典顺序的下一个较大的排列 (函数模板) | |
(C++20) |
产生某个元素范围的按字典序下一个较大的排列 (niebloid) |
产生某个元素范围的按字典顺序的下一个较小的排列 (函数模板) | |
(C++20) |
产生某个元素范围的按字典序下一个较小的排列 (niebloid) |
数值运算 | |
在标头
<numeric> 定义 | |
(C++11) |
用从起始值开始连续递增的值填充一个范围 (函数模板) |
(C++23) |
用从起始值开始连续递增的值填充一个范围 (niebloid) |
对一个范围内的元素求和 (函数模板) | |
计算两个范围的元素的内积 (函数模板) | |
计算范围内各相邻元素之间的差 (函数模板) | |
计算范围内元素的部分和 (函数模板) | |
(C++17) |
类似 std::accumulate,但不依序执行 (函数模板) |
(C++17) |
类似 std::partial_sum,第 i 个和中排除第 i 个输入 (函数模板) |
(C++17) |
类似 std::partial_sum,第 i 个和中包含第 i 个输入 (函数模板) |
(C++17) |
应用一个函数对象,然后以乱序规约 (函数模板) |
(C++17) |
应用一个函数对象,然后进行排除扫描 (函数模板) |
(C++17) |
应用一个函数对象,然后进行包含扫描 (函数模板) |
未初始化内存上的操作 |
在标头
<memory> 定义 | |
将范围内的对象复制到未初始化的内存区域 (函数模板) | |
(C++20) |
复制元素范围到未初始化的内存区域 (niebloid) |
(C++11) |
将指定数量的对象复制到未初始化的内存区域 (函数模板) |
(C++20) |
复制一定量元素到未初始化的内存区域 (niebloid) |
复制一个对象到以范围定义的未初始化内存区域 (函数模板) | |
(C++20) |
复制一个对象到范围所定义的未初始化的内存区域 (niebloid) |
复制一个对象到以起点和计数定义的未初始化内存区域 (函数模板) | |
(C++20) |
复制一个对象到起始与计数所定义的未初始化的内存区域 (niebloid) |
(C++17) |
移动一个范围的对象到未初始化的内存区域 (函数模板) |
(C++20) |
移动对象范围到未初始化的内存区域 (niebloid) |
(C++17) |
移动一定数量对象到未初始化内存区域 (函数模板) |
(C++20) |
移动一定量对象到未初始化的内存区域 (niebloid) |
在范围所定义的未初始化的内存区域以默认初始化构造对象 (函数模板) | |
在范围所定义的未初始化的内存区域以默认初始化构造对象 (niebloid) | |
在起始和计数所定义的未初始化内存区域用默认初始化构造对象 (函数模板) | |
在起始与计数所定义的未初始化的内存区域以默认初始化构造对象 (niebloid) | |
在范围所定义的未初始化内存中用值初始化构造对象 (函数模板) | |
在范围所定义的未初始化的内存区域以值初始化构造对象 (niebloid) | |
在起始和计数所定义的未初始化内存区域以值初始化构造对象 (函数模板) | |
在起始与计数所定义的未初始化的内存区域以值初始化构造对象 (niebloid) | |
(C++17) |
销毁一个范围中的对象 (函数模板) |
(C++20) |
销毁范围中的元素 (niebloid) |
(C++17) |
销毁范围中一定数量的对象 (函数模板) |
(C++20) |
销毁范围中一定量的元素 (niebloid) |
(C++17) |
销毁在给定地址的对象 (函数模板) |
(C++20) |
销毁位于给定地址的元素 (niebloid) |
(C++20) |
在给定地址创建对象 (函数模板) |
(C++20) |
在给定地址创建对象 (niebloid) |
C 库 | |
在标头
<cstdlib> 定义 | |
对未指定类型的元素的一个范围进行排序 (函数) | |
在未指定类型的数组中搜索元素 (函数) |