Constrained algorithms (since C++20)

From cppreference.com
< cpp‎ | algorithm
 
 
Algorithm library
Constrained algorithms and algorithms on ranges (C++20)
Constrained algorithms, e.g. ranges::copy, ranges::sort, ...
Execution policies (C++17)
Non-modifying sequence operations
Batch operations
(C++17)
Search operations
(C++11)                (C++11)(C++11)

Modifying sequence operations
Copy operations
(C++11)
(C++11)
Swap operations
Transformation operations
Generation operations
Removing operations
Order-changing operations
(until C++17)(C++11)
(C++20)(C++20)
Sampling operations
(C++17)

Sorting and related operations
Partitioning operations
Sorting operations
Binary search operations
(on partitioned ranges)
Set operations (on sorted ranges)
Merge operations (on sorted ranges)
Heap operations
Minimum/maximum operations
(C++11)
(C++17)
Lexicographical comparison operations
Permutation operations
C library
Numeric operations
Operations on uninitialized memory
 
Constrained algorithms
All names in this menu belong to namespace std::ranges
Non-modifying sequence operations
Modifying sequence operations
Partitioning operations
Sorting operations
Binary search operations (on sorted ranges)
       
       
Set operations (on sorted ranges)
Heap operations
Minimum/maximum operations
       
       
Permutation operations
Fold operations
Numeric operations
(C++23)            
Operations on uninitialized storage
Return types
 

C++20 provides constrained versions of most algorithms in the namespace std::ranges. In these algorithms, a range can be specified as either an iterator-sentinel pair or as a single range argument, and projections and pointer-to-member callables are supported. Additionally, the return types of most algorithms have been changed to return all potentially useful information computed during the execution of the algorithm.

Algorithm function objects

An algorithm function object (AFO), informally known as niebloid, is a customization point object (CPO) that is specified as one or more overloaded function templates. The name of these function templates designates the corresponding algorithm function object.

For an algorithm function object o, let S be the corresponding set of function templates. Then for any sequence of arguments args..., o(args...) is expression-equivalent to s(args...), where the result of name lookup for s is the overload set S.

The constrained algorithms in the namespace std::ranges are defined as algorithm function objects. As a result:

Constrained algorithms

Defined in header <algorithm>
Defined in namespace std::ranges
Non-modifying sequence operations
checks if a predicate is true for all, any or none of the elements in a range
(algorithm function object)
applies a function to a range of elements
(algorithm function object)
applies a function object to the first N elements of a sequence
(algorithm function object)
returns the number of elements satisfying specific criteria
(algorithm function object)
finds the first position where two ranges differ
(algorithm function object)
determines if two sets of elements are the same
(algorithm function object)
returns true if one range is lexicographically less than another
(algorithm function object)
finds the first element satisfying specific criteria
(algorithm function object)
finds the last element satisfying specific criteria
(algorithm function object)
finds the last sequence of elements in a certain range
(algorithm function object)
searches for any one of a set of elements
(algorithm function object)
finds the first two adjacent items that are equal (or satisfy a given predicate)
(algorithm function object)
searches for the first occurrence of a range of elements
(algorithm function object)
searches for the first occurrence of a number consecutive copies of an element in a range
(algorithm function object)
checks if the range contains the given element or subrange
(algorithm function object)
checks whether a range starts with another range
(algorithm function object)
checks whether a range ends with another range
(algorithm function object)
Modifying sequence operations
copies a range of elements to a new location
(algorithm function object)
copies a number of elements to a new location
(algorithm function object)
copies a range of elements in backwards order
(algorithm function object)
moves a range of elements to a new location
(algorithm function object)
moves a range of elements to a new location in backwards order
(algorithm function object)
assigns a range of elements a certain value
(algorithm function object)
assigns a value to a number of elements
(algorithm function object)
applies a function to a range of elements
(algorithm function object)
saves the result of a function in a range
(algorithm function object)
saves the result of N applications of a function
(algorithm function object)
removes elements satisfying specific criteria
(algorithm function object)
copies a range of elements omitting those that satisfy specific criteria
(algorithm function object)
replaces all values satisfying specific criteria with another value
(algorithm function object)
copies a range, replacing elements satisfying specific criteria with another value
(algorithm function object)
swaps two ranges of elements
(algorithm function object)
reverses the order of elements in a range
(algorithm function object)
creates a copy of a range that is reversed
(algorithm function object)
rotates the order of elements in a range
(algorithm function object)
copies and rotate a range of elements
(algorithm function object)
randomly re-orders elements in a range
(algorithm function object)
shifts elements in a range
(algorithm function object)
selects N random elements from a sequence
(algorithm function object)
removes consecutive duplicate elements in a range
(algorithm function object)
creates a copy of some range of elements that contains no consecutive duplicates
(algorithm function object)
Partitioning operations
determines if the range is partitioned by the given predicate
(algorithm function object)
divides a range of elements into two groups
(algorithm function object)
copies a range dividing the elements into two groups
(algorithm function object)
divides elements into two groups while preserving their relative order
(algorithm function object)
locates the partition point of a partitioned range
(algorithm function object)
Sorting operations
checks whether a range is sorted into ascending order
(algorithm function object)
finds the largest sorted subrange
(algorithm function object)
sorts a range into ascending order
(algorithm function object)
sorts the first N elements of a range
(algorithm function object)
copies and partially sorts a range of elements
(algorithm function object)
sorts a range of elements while preserving order between equal elements
(algorithm function object)
partially sorts the given range making sure that it is partitioned by the given element
(algorithm function object)
Binary search operations (on sorted ranges)
returns an iterator to the first element not less than the given value
(algorithm function object)
returns an iterator to the first element greater than a certain value
(algorithm function object)
determines if an element exists in a partially-ordered range
(algorithm function object)
returns range of elements matching a specific key
(algorithm function object)
Set operations (on sorted ranges)
merges two sorted ranges
(algorithm function object)
merges two ordered ranges in-place
(algorithm function object)
returns true if one sequence is a subsequence of another
(algorithm function object)
computes the difference between two sets
(algorithm function object)
computes the intersection of two sets
(algorithm function object)
computes the symmetric difference between two sets
(algorithm function object)
computes the union of two sets
(algorithm function object)
Heap operations
checks if the given range is a max heap
(algorithm function object)
finds the largest subrange that is a max heap
(algorithm function object)
creates a max heap out of a range of elements
(algorithm function object)
adds an element to a max heap
(algorithm function object)
removes the largest element from a max heap
(algorithm function object)
turns a max heap into a range of elements sorted in ascending order
(algorithm function object)
Minimum/maximum operations
returns the greater of the given values
(algorithm function object)
returns the largest element in a range
(algorithm function object)
returns the smaller of the given values
(algorithm function object)
returns the smallest element in a range
(algorithm function object)
returns the smaller and larger of two elements
(algorithm function object)
returns the smallest and the largest elements in a range
(algorithm function object)
clamps a value between a pair of boundary values
(algorithm function object)
Permutation operations
determines if a sequence is a permutation of another sequence
(algorithm function object)
generates the next greater lexicographic permutation of a range of elements
(algorithm function object)
generates the next smaller lexicographic permutation of a range of elements
(algorithm function object)

Constrained numeric operations

Defined in header <numeric>
Defined in namespace std::ranges
fills a range with successive increments of the starting value
(algorithm function object)

Constrained fold operations

Defined in header <algorithm>
Defined in namespace std::ranges
left-folds a range of elements
(algorithm function object)
left-folds a range of elements using the first element as an initial value
(algorithm function object)
right-folds a range of elements
(algorithm function object)
right-folds a range of elements using the last element as an initial value
(algorithm function object)
left-folds a range of elements, and returns a pair (iterator, value)
(algorithm function object)
left-folds a range of elements using the first element as an initial value, and returns a pair (iterator, optional)
(algorithm function object)

Constrained uninitialized memory algorithms

Defined in header <memory>
Defined in namespace std::ranges
copies a range of objects to an uninitialized area of memory
(algorithm function object)
copies a number of objects to an uninitialized area of memory
(algorithm function object)
copies an object to an uninitialized area of memory, defined by a range
(algorithm function object)
copies an object to an uninitialized area of memory, defined by a start and a count
(algorithm function object)
moves a range of objects to an uninitialized area of memory
(algorithm function object)
moves a number of objects to an uninitialized area of memory
(algorithm function object)
constructs objects by default-initialization in an uninitialized area of memory, defined by a range
(algorithm function object)
constructs objects by default-initialization in an uninitialized area of memory, defined by a start and count
(algorithm function object)
constructs objects by value-initialization in an uninitialized area of memory, defined by a range
(algorithm function object)
constructs objects by value-initialization in an uninitialized area of memory, defined by a start and a count
(algorithm function object)
destroys a range of objects
(algorithm function object)
destroys a number of objects in a range
(algorithm function object)
destroys an object at a given address
(algorithm function object)
creates an object at a given address
(algorithm function object)

Constrained random number algorithms

Defined in header <random>
Defined in namespace std::ranges
fills a range with random numbers from a uniform random bit generator
(algorithm function object)

Return types

Defined in header <algorithm>
Defined in namespace std::ranges
provides a way to store an iterator and a function object as a single unit
(class template)
provides a way to store two iterators as a single unit
(class template)
provides a way to store two iterators as a single unit
(class template)
provides a way to store three iterators as a single unit
(class template)
provides a way to store three iterators as a single unit
(class template)
provides a way to store two objects or references of the same type as a single unit
(class template)
provides a way to store an iterator and a boolean flag as a single unit
(class template)
provides a way to store an iterator and a value as a single unit
(class template)
provides a way to store an iterator and a value as a single unit
(class template)

Notes

Feature-test macro Value Std Feature
__cpp_lib_algorithm_default_value_type 202403L (C++26) List-initialization for algorithms
__cpp_lib_ranges 201911L (C++20) Ranges library and constrained algorithms
__cpp_lib_ranges_contains 202207L (C++23) std::ranges::contains
__cpp_lib_ranges_find_last 202207L (C++23) std::ranges::find_last
__cpp_lib_ranges_fold 202207L (C++23) std::ranges fold algorithms
__cpp_lib_ranges_iota 202202L (C++23) std::ranges::iota
__cpp_lib_ranges_starts_ends_with 202106L (C++23) std::ranges::starts_with, std::ranges::ends_with
__cpp_lib_shift 201806L (C++20) std::shift_left, std::shift_right
202202L (C++23) std::ranges::shift_left, std::ranges::shift_right
__cpp_lib_ranges_generate_random 202403L (C++26) std::ranges::generate_random

Defect reports

The following behavior-changing defect reports were applied retroactively to previously published C++ standards.

DR Applied to Behavior as published Correct behavior
P3136R1 C++20 niebloids were allowed to be specified as special entities
other than function objects
required to be specified as function objects