有制约算法 (C++20 起)

来自cppreference.com
< cpp‎ | algorithm
 
 
算法库
有制约算法及范围上的算法 (C++20)
概念与工具std::Sortable, std::projected, ...
有制约算法std::ranges::copy, std::ranges::sort, ...
执行策略 (C++17)
不修改序列的操作
(C++11)(C++11)(C++11)
(C++17)
修改序列的操作
未初始化存储上的操作
划分操作
排序操作
(C++11)
二分搜索操作
集合操作(在已排序范围上)
堆操作
(C++11)
最小/最大操作
(C++11)
(C++17)

排列
数值运算
C 库
 
有制约算法
不修改序列的操作
                                        
                                        
修改系列的操作
未初始化存储上的操作
划分操作
                                                  
排序操作
二分搜索操作
集合操作(在已排序范围上)
堆操作
最小/最大操作
排列
 

C++20 在命名空间 std::ranges 中提供大多数算法的有制约版本,能以迭代器-哨位对或单个 range 参数指定范围,并且支持投影和指向成员指针可调用对象。另外更改了大多数算法的返回类型,以返回算法执行过程中计算的所有潜在有用信息。

目录

[编辑] 算法概念与工具

头文件 <iterator> 提供为简化常用算法操作的制约而设计的概念和工具模板集合。

定义于头文件 <iterator>
定义于命名空间 std
间接可调用对象
指定可调用类型能以解引用某个 readable 类型的结果进行调用
(概念) [编辑]
指定可调用类型,在以解引用一个 readable 类型的结果进行调用时,满足 predicate
(概念) [编辑]
指定可调用类型,在以解引用两个 readable 类型的结果进行调用时,满足 predicate
(概念) [编辑]
指定可调用类型,在以解引用两个 readable 类型的结果进行调用时,满足 strict_weak_order
(概念) [编辑]
常用算法要求
指定可从 readable 类型移动值给 writable 类型
(概念) [编辑]
指定可从 readable 类型移动值给 writable 类型,且该移动可以通过中间对象进行
(概念) [编辑]
指定可从 readable 类型复制值给 writable 类型
(概念) [编辑]
指定可从 readable 类型复制值给 writable 类型,且该复制可以通过中间对象进行
(概念) [编辑]
指定能交换两个 readable 类型所引用的值
(概念) [编辑]
指定能比较两个 readable 类型所引用的值
(概念) [编辑]
指定在原位重排元素的算法的共用要求
(概念) [编辑]
指定通过复制元素将已排序序列归并到输出序列中的算法的要求
(概念) [编辑]
指定重排序列为有序序列的算法的共用要求
(概念) [编辑]
工具
计算在解引用某组 readable 类型的结果上调用可调用对象的结果
(别名模板) [编辑]
用于对接受投影的算法指定制约的辅助模板
(类模板) [编辑]

[编辑] 有制约算法

定义于头文件 <algorithm>
定义于命名空间 std::ranges
不修改序列的操作
检查谓词是否对范围中所有、任一或无元素为 true
(niebloid) [编辑]
应用函数到范围中的元素
(niebloid) [编辑]
返回满足指定判别标准的元素数
(niebloid) [编辑]
寻找两个范围出现不同的首个位置
(niebloid) [编辑]
确定两个元素集合是否是相同的
(niebloid) [编辑]
当一个范围按字典顺序小于另一个范围时,返回 true
(niebloid) [编辑]
寻找首个满足特定判别标准的元素
(niebloid) [编辑]
在特定范围中寻找最后出现的元素序列
(niebloid) [编辑]
搜索元素集合中的任意元素
(niebloid) [编辑]
查找首对相邻的相同(或满足给定谓词的)元素
(niebloid) [编辑]
搜索一个元素范围
(niebloid) [编辑]
在范围中搜索一定量的某个元素的连续副本
(niebloid) [编辑]
修改序列的操作
将某一范围的元素复制到一个新的位置
(niebloid) [编辑]
将一定数目的元素复制到一个新的位置
(niebloid) [编辑]
按从后往前的顺序复制一个范围内的元素
(niebloid) [编辑]
将某一范围的元素移动到一个新的位置
(niebloid) [编辑]
按从后往前的顺序移动某一范围的元素到新的位置
(niebloid) [编辑]
将一个给定值复制赋值给一个范围内的每个元素
(niebloid) [编辑]
将一个值复制赋值给一定量的元素
(niebloid) [编辑]
将一个函数应用于某一范围的各个元素
(niebloid) [编辑]
保存函数结果到一个范围中
(niebloid) [编辑]
保存 N 次函数应用的结果
(niebloid) [编辑]
移除满足特定判别标准的元素
(niebloid) [编辑]
复制一个范围的元素,忽略满足特定判别标准的元素
(niebloid) [编辑]
将所有满足特定判别标准的值替换为另一个值
(niebloid) [编辑]
复制一个范围内的元素,并将满足特定判别标准的元素替换为另一个值
(niebloid) [编辑]
交换两个范围的元素
(niebloid) [编辑]
逆转范围中的元素顺序
(niebloid) [编辑]
创建一个范围的逆向副本
(niebloid) [编辑]
旋转范围中的元素顺序
(niebloid) [编辑]
复制并旋转元素范围
(niebloid) [编辑]
随机重排范围中的元素
(niebloid) [编辑]
移除范围中的连续重复元素
(niebloid) [编辑]
创建某范围的不含连续重复元素的副本
(niebloid) [编辑]
划分操作
判断范围是否已按给定的谓词划分
(niebloid) [编辑]
将范围中的元素分为二组
(niebloid) [编辑]
复制一个范围,将各元素分为二组
(niebloid) [编辑]
将元素分成二组,同时保持其相对顺序
(niebloid) [编辑]
定位已划分范围的划分点
(niebloid) [编辑]
排序操作
检查范围是否以升序排序
(niebloid) [编辑]
寻找最大的已排序子范围
(niebloid) [编辑]
将范围按升序排序
(niebloid) [编辑]
排序一个范围的前 N 个元素
(niebloid) [编辑]
对范围内的元素进行复制并部分排序
(niebloid) [编辑]
将范围内的元素排序,同时保持相等的元素之间的顺序
(niebloid) [编辑]
将给定的范围部分排序,确保其按给定元素划分
(niebloid) [编辑]
二分搜索操作(在已排序范围上)
返回指向首个不小于给定值的元素的迭代器
(niebloid) [编辑]
返回指向首个大于某值的元素的迭代器
(niebloid) [编辑]
确定元素是否存在于某范围中
(niebloid) [编辑]
返回匹配特定键值的元素范围
(niebloid) [编辑]
集合操作(在已排序范围上)
归并二个已排序范围
(niebloid) [编辑]
在原位归并两个有序范围
(niebloid) [编辑]
若一个集合是另一个的子集则返回 true
(niebloid) [编辑]
计算两个集合的差集
(niebloid) [编辑]
计算两个集合的交集
(niebloid) [编辑]
计算两个集合的对称差
(niebloid) [编辑]
计算两个集合的并集
(niebloid) [编辑]
堆操作
检查给定范围是否为最大堆
(niebloid) [编辑]
寻找能成为最大堆的最大子范围
(niebloid) [编辑]
从一个元素范围创建出一个最大堆
(niebloid) [编辑]
将一个元素加入到一个最大堆
(niebloid) [编辑]
从最大堆中移除最大元素
(niebloid) [编辑]
将一个最大堆变成一个按升序排序的元素范围
(niebloid) [编辑]
最小/最大操作
返回给定值的较大者
(niebloid) [编辑]
返回范围中的最大元素
(niebloid) [编辑]
返回给定值的较小者
(niebloid) [编辑]
返回范围中的最小元素
(niebloid) [编辑]
返回两个元素的较小和较大者
(niebloid) [编辑]
返回范围中的最小和最大元素
(niebloid) [编辑]
排列操作
确定一个序列是否为另一序列的重排
(niebloid) [编辑]
产生某个元素范围的按字典序下一个较大的排列
(niebloid) [编辑]
产生某个元素范围的按字典序下一个较小的排列
(niebloid) [编辑]

[编辑] 有制约的未初始化内存算法

定义于头文件 <memory>
定义于命名空间 std::ranges
复制元素范围到未初始化的内存区域
(niebloid) [编辑]
复制一定量元素到未初始化的内存区域
(niebloid) [编辑]
复制一个对象到范围所定义的未初始化的内存区域
(niebloid) [编辑]
复制一个对象到起始与计数所定义的未初始化的内存区域
(niebloid) [编辑]
移动对象范围到未初始化的内存区域
(niebloid) [编辑]
移动一定量对象到未初始化的内存区域
(niebloid) [编辑]
在范围所定义的未初始化的内存区域以默认初始化构造对象
(niebloid) [编辑]
在起始与计数所定义的未初始化的内存区域以默认初始化构造对象
(niebloid) [编辑]
在范围所定义的未初始化的内存区域以值初始化构造对象
(niebloid) [编辑]
在起始与计数所定义的未初始化的内存区域以值初始化构造对象
(niebloid) [编辑]
销毁位于给定地址的元素
(niebloid) [编辑]
(C++20)
销毁范围中的元素
(niebloid) [编辑]
(C++20)
销毁范围中一定量的元素
(niebloid) [编辑]