13e519524SHoward Hinnant// -*- C++ -*-
2eb8650a7SLouis Dionne//===----------------------------------------------------------------------===//
33e519524SHoward Hinnant//
457b08b09SChandler Carruth// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
557b08b09SChandler Carruth// See https://llvm.org/LICENSE.txt for license information.
657b08b09SChandler Carruth// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
73e519524SHoward Hinnant//
83e519524SHoward Hinnant//===----------------------------------------------------------------------===//
93e519524SHoward Hinnant
103e519524SHoward Hinnant#ifndef _LIBCPP_ALGORITHM
113e519524SHoward Hinnant#define _LIBCPP_ALGORITHM
123e519524SHoward Hinnant
133e519524SHoward Hinnant/*
143e519524SHoward Hinnant    algorithm synopsis
153e519524SHoward Hinnant
163e519524SHoward Hinnant#include <initializer_list>
173e519524SHoward Hinnant
183e519524SHoward Hinnantnamespace std
193e519524SHoward Hinnant{
203e519524SHoward Hinnant
21d3729bb3SNikolas Klausernamespace ranges {
2279a2b4baSKonstantin Varlamov
2379a2b4baSKonstantin Varlamov  // [algorithms.results], algorithm result types
241e77b396SNikolas Klauser  template <class I, class F>
251e77b396SNikolas Klauser    struct in_fun_result;     // since C++20
261e77b396SNikolas Klauser
27d3729bb3SNikolas Klauser  template <class I1, class I2>
28d3729bb3SNikolas Klauser    struct in_in_result;      // since C++20
29f3514af4SNikolas Klauser
3079a2b4baSKonstantin Varlamov  template <class I, class O>
3179a2b4baSKonstantin Varlamov    struct in_out_result;  // since C++20
3279a2b4baSKonstantin Varlamov
33f3514af4SNikolas Klauser  template <class I1, class I2, class O>
34f3514af4SNikolas Klauser    struct in_in_out_result;  // since C++20
35610979b3SNikolas Klauser
36610979b3SNikolas Klauser  template <class I, class O1, class O2>
37610979b3SNikolas Klauser    struct in_out_out_result; // since C++20
381e77b396SNikolas Klauser
39807766beSNikolas Klauser  template <class I1, class I2>
40807766beSNikolas Klauser    struct min_max_result;    // since C++20
41807766beSNikolas Klauser
4268f4131cSNikolas Klauser  template <class I>
4368f4131cSNikolas Klauser    struct in_found_result;   // since C++20
4468f4131cSNikolas Klauser
453b470d1cSNikolas Klauser  template<forward_iterator I, sentinel_for<I> S, class Proj = identity,
463b470d1cSNikolas Klauser    indirect_strict_weak_order<projected<I, Proj>> Comp = ranges::less>             // since C++20
473b470d1cSNikolas Klauser  constexpr I min_element(I first, S last, Comp comp = {}, Proj proj = {});
483b470d1cSNikolas Klauser
493b470d1cSNikolas Klauser  template<forward_range R, class Proj = identity,
503b470d1cSNikolas Klauser    indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less> // since C++20
513b470d1cSNikolas Klauser  constexpr borrowed_iterator_t<R> min_element(R&& r, Comp comp = {}, Proj proj = {});
52c2cd15a6SNikolas Klauser
5340f7fca3SNikolas Klauser  template<forward_iterator I, sentinel_for<I> S, class Proj = identity,
5440f7fca3SNikolas Klauser    indirect_strict_weak_order<projected<I, Proj>> Comp = ranges::less>
5540f7fca3SNikolas Klauser  constexpr I ranges::max_element(I first, S last, Comp comp = {}, Proj proj = {});                        // since C++20
5640f7fca3SNikolas Klauser
5740f7fca3SNikolas Klauser  template<forward_range R, class Proj = identity,
5840f7fca3SNikolas Klauser    indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
5940f7fca3SNikolas Klauser  constexpr borrowed_iterator_t<R> ranges::max_element(R&& r, Comp comp = {}, Proj proj = {});             // since C++20
6040f7fca3SNikolas Klauser
6179a2b4baSKonstantin Varlamov  template<class I1, class I2>
6279a2b4baSKonstantin Varlamov    using mismatch_result = in_in_result<I1, I2>;
6379a2b4baSKonstantin Varlamov
64c2cd15a6SNikolas Klauser  template <input_iterator I1, sentinel_for<_I1> S1, input_iterator I2, sentinel_for<_I2> S2,
65c2cd15a6SNikolas Klauser          class Pred = ranges::equal_to, class Proj1 = identity, class Proj2 = identity>
66c2cd15a6SNikolas Klauser    requires indirectly_comparable<I1, I2, Pred, Proj1, Proj2>
67c2cd15a6SNikolas Klauser  constexpr mismatch_result<_I1, _I2>
68c2cd15a6SNikolas Klauser  mismatch()(I1 first1, S1 last1, I2 first2, S2 last2, Pred pred = {}, Proj1 proj1 = {}, Proj2 proj2 = {}) // since C++20
69c2cd15a6SNikolas Klauser
70c2cd15a6SNikolas Klauser  template <input_range R1, input_range R2,
71c2cd15a6SNikolas Klauser          class Pred = ranges::equal_to, class Proj1 = identity, class Proj2 = identity>
72c2cd15a6SNikolas Klauser    requires indirectly_comparable<iterator_t<R1>, iterator_t<R2>, Pred, Proj1, Proj2>
73c2cd15a6SNikolas Klauser  constexpr mismatch_result<borrowed_iterator_t<R1>, borrowed_iterator_t<R2>>
74c2cd15a6SNikolas Klauser  mismatch(R1&& r1, R2&& r2, Pred pred = {}, Proj1 proj1 = {}, Proj2 proj2 = {})                           // since C++20
75ee0f8c40SNikolas Klauser
76ee0f8c40SNikolas Klauser    requires indirect_binary_predicate<ranges::equal_to, projected<I, Proj>, const T*>
77ee0f8c40SNikolas Klauser    constexpr I find(I first, S last, const T& value, Proj proj = {});              // since C++20
78ee0f8c40SNikolas Klauser
79ee0f8c40SNikolas Klauser  template<input_range R, class T, class Proj = identity>
80ee0f8c40SNikolas Klauser    requires indirect_binary_predicate<ranges::equal_to, projected<iterator_t<R>, Proj>, const T*>
81ee0f8c40SNikolas Klauser    constexpr borrowed_iterator_t<R>
82ee0f8c40SNikolas Klauser      find(R&& r, const T& value, Proj proj = {});                                  // since C++20
83ee0f8c40SNikolas Klauser
84ee0f8c40SNikolas Klauser  template<input_iterator I, sentinel_for<I> S, class Proj = identity,
85ee0f8c40SNikolas Klauser           indirect_unary_predicate<projected<I, Proj>> Pred>
86ee0f8c40SNikolas Klauser    constexpr I find_if(I first, S last, Pred pred, Proj proj = {});                // since C++20
87ee0f8c40SNikolas Klauser
88ee0f8c40SNikolas Klauser  template<input_range R, class Proj = identity,
89ee0f8c40SNikolas Klauser           indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
90ee0f8c40SNikolas Klauser    constexpr borrowed_iterator_t<R>
91ee0f8c40SNikolas Klauser      find_if(R&& r, Pred pred, Proj proj = {});                                    // since C++20
92ee0f8c40SNikolas Klauser
93ee0f8c40SNikolas Klauser  template<input_iterator I, sentinel_for<I> S, class Proj = identity,
94ee0f8c40SNikolas Klauser           indirect_unary_predicate<projected<I, Proj>> Pred>
95ee0f8c40SNikolas Klauser    constexpr I find_if_not(I first, S last, Pred pred, Proj proj = {});            // since C++20
96ee0f8c40SNikolas Klauser
97ee0f8c40SNikolas Klauser  template<input_range R, class Proj = identity,
98ee0f8c40SNikolas Klauser           indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
99ee0f8c40SNikolas Klauser    constexpr borrowed_iterator_t<R>
100ee0f8c40SNikolas Klauser      find_if_not(R&& r, Pred pred, Proj proj = {});                                // since C++20
101f83d833eSNikolas Klauser
102f83d833eSNikolas Klauser  template<class T, class Proj = identity,
103f83d833eSNikolas Klauser           indirect_strict_weak_order<projected<const T*, Proj>> Comp = ranges::less>
104f83d833eSNikolas Klauser    constexpr const T& min(const T& a, const T& b, Comp comp = {}, Proj proj = {}); // since C++20
105f83d833eSNikolas Klauser
106f83d833eSNikolas Klauser  template<copyable T, class Proj = identity,
107f83d833eSNikolas Klauser           indirect_strict_weak_order<projected<const T*, Proj>> Comp = ranges::less>
108f83d833eSNikolas Klauser    constexpr T min(initializer_list<T> r, Comp comp = {}, Proj proj = {});         // since C++20
109f83d833eSNikolas Klauser
110f83d833eSNikolas Klauser template<input_range R, class Proj = identity,
111f83d833eSNikolas Klauser          indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
112f83d833eSNikolas Klauser   requires indirectly_copyable_storable<iterator_t<R>, range_value_t<R>*>
113f83d833eSNikolas Klauser   constexpr range_value_t<R>
114f83d833eSNikolas Klauser     min(R&& r, Comp comp = {}, Proj proj = {});                                    // since C++20
115e476df56SNikolas Klauser
116e476df56SNikolas Klauser  template<class T, class Proj = identity,
117e476df56SNikolas Klauser           indirect_strict_weak_order<projected<const T*, Proj>> Comp = ranges::less>
118e476df56SNikolas Klauser    constexpr const T& max(const T& a, const T& b, Comp comp = {}, Proj proj = {}); // since C++20
119e476df56SNikolas Klauser
120e476df56SNikolas Klauser  template<copyable T, class Proj = identity,
121e476df56SNikolas Klauser           indirect_strict_weak_order<projected<const T*, Proj>> Comp = ranges::less>
122e476df56SNikolas Klauser    constexpr T max(initializer_list<T> r, Comp comp = {}, Proj proj = {});         // since C++20
123e476df56SNikolas Klauser
124e476df56SNikolas Klauser  template<input_range R, class Proj = identity,
125e476df56SNikolas Klauser           indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
126e476df56SNikolas Klauser    requires indirectly_copyable_storable<iterator_t<R>, range_value_t<R>*>
127e476df56SNikolas Klauser    constexpr range_value_t<R>
128e476df56SNikolas Klauser      max(R&& r, Comp comp = {}, Proj proj = {});                                   // since C++20
1293ba8548cSNikolas Klauser
1303ba8548cSNikolas Klauser  template<class I, class O>
1313ba8548cSNikolas Klauser    using unary_transform_result = in_out_result<I, O>;                             // since C++20
1323ba8548cSNikolas Klauser
1333ba8548cSNikolas Klauser  template<class I1, class I2, class O>
1343ba8548cSNikolas Klauser    using binary_transform_result = in_in_out_result<I1, I2, O>;                    // since C++20
1353ba8548cSNikolas Klauser
1363ba8548cSNikolas Klauser  template<input_iterator I, sentinel_for<I> S, weakly_incrementable O,
1373ba8548cSNikolas Klauser           copy_constructible F, class Proj = identity>
1383ba8548cSNikolas Klauser    requires indirectly_writable<O, indirect_result_t<F&, projected<I, Proj>>>
1393ba8548cSNikolas Klauser    constexpr ranges::unary_transform_result<I, O>
1403ba8548cSNikolas Klauser      transform(I first1, S last1, O result, F op, Proj proj = {});                 // since C++20
1413ba8548cSNikolas Klauser
1423ba8548cSNikolas Klauser  template<input_range R, weakly_incrementable O, copy_constructible F,
1433ba8548cSNikolas Klauser           class Proj = identity>
1443ba8548cSNikolas Klauser    requires indirectly_writable<O, indirect_result_t<F&, projected<iterator_t<R>, Proj>>>
1453ba8548cSNikolas Klauser    constexpr ranges::unary_transform_result<borrowed_iterator_t<R>, O>
1463ba8548cSNikolas Klauser      transform(R&& r, O result, F op, Proj proj = {});                             // since C++20
1473ba8548cSNikolas Klauser
1483ba8548cSNikolas Klauser  template<input_iterator I1, sentinel_for<I1> S1, input_iterator I2, sentinel_for<I2> S2,
1493ba8548cSNikolas Klauser           weakly_incrementable O, copy_constructible F, class Proj1 = identity,
1503ba8548cSNikolas Klauser           class Proj2 = identity>
1513ba8548cSNikolas Klauser    requires indirectly_writable<O, indirect_result_t<F&, projected<I1, Proj1>,
1523ba8548cSNikolas Klauser                                           projected<I2, Proj2>>>
1533ba8548cSNikolas Klauser    constexpr ranges::binary_transform_result<I1, I2, O>
1543ba8548cSNikolas Klauser      transform(I1 first1, S1 last1, I2 first2, S2 last2, O result,
1553ba8548cSNikolas Klauser                        F binary_op, Proj1 proj1 = {}, Proj2 proj2 = {});           // since C++20
1563ba8548cSNikolas Klauser
1573ba8548cSNikolas Klauser  template<input_range R1, input_range R2, weakly_incrementable O,
1583ba8548cSNikolas Klauser           copy_constructible F, class Proj1 = identity, class Proj2 = identity>
1593ba8548cSNikolas Klauser    requires indirectly_writable<O, indirect_result_t<F&, projected<iterator_t<R1>, Proj1>,
1603ba8548cSNikolas Klauser                                           projected<iterator_t<R2>, Proj2>>>
1613ba8548cSNikolas Klauser    constexpr ranges::binary_transform_result<borrowed_iterator_t<R1>, borrowed_iterator_t<R2>, O>
1623ba8548cSNikolas Klauser      transform(R1&& r1, R2&& r2, O result,
1633ba8548cSNikolas Klauser                        F binary_op, Proj1 proj1 = {}, Proj2 proj2 = {});           // since C++20
1641306b102SNikolas Klauser
1651306b102SNikolas Klauser  template<input_iterator I, sentinel_for<I> S, class T, class Proj = identity>
1661306b102SNikolas Klauser    requires indirect_binary_predicate<ranges::equal_to, projected<I, Proj>, const T*>
1671306b102SNikolas Klauser    constexpr iter_difference_t<I>
1681306b102SNikolas Klauser      count(I first, S last, const T& value, Proj proj = {});                       // since C++20
1691306b102SNikolas Klauser
1701306b102SNikolas Klauser  template<input_range R, class T, class Proj = identity>
1711306b102SNikolas Klauser    requires indirect_binary_predicate<ranges::equal_to, projected<iterator_t<R>, Proj>, const T*>
1721306b102SNikolas Klauser    constexpr range_difference_t<R>
1731306b102SNikolas Klauser      count(R&& r, const T& value, Proj proj = {});                                 // since C++20
1741306b102SNikolas Klauser
1751306b102SNikolas Klauser  template<input_iterator I, sentinel_for<I> S, class Proj = identity,
1761306b102SNikolas Klauser           indirect_unary_predicate<projected<I, Proj>> Pred>
1771306b102SNikolas Klauser    constexpr iter_difference_t<I>
1781306b102SNikolas Klauser      count_if(I first, S last, Pred pred, Proj proj = {});                         // since C++20
1791306b102SNikolas Klauser
1801306b102SNikolas Klauser  template<input_range R, class Proj = identity,
1811306b102SNikolas Klauser           indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
1821306b102SNikolas Klauser    constexpr range_difference_t<R>
1831306b102SNikolas Klauser      count_if(R&& r, Pred pred, Proj proj = {});                                   // since C++20
18458d9ab70SNikolas Klauser
18579a2b4baSKonstantin Varlamov  template<class T>
18679a2b4baSKonstantin Varlamov  using minmax_result = min_max_result<T>;
18779a2b4baSKonstantin Varlamov
18858d9ab70SNikolas Klauser  template<class T, class Proj = identity,
18958d9ab70SNikolas Klauser           indirect_strict_weak_order<projected<const T*, Proj>> Comp = ranges::less>
19058d9ab70SNikolas Klauser    constexpr ranges::minmax_result<const T&>
19158d9ab70SNikolas Klauser      minmax(const T& a, const T& b, Comp comp = {}, Proj proj = {});                     // since C++20
19258d9ab70SNikolas Klauser
19358d9ab70SNikolas Klauser  template<copyable T, class Proj = identity,
19458d9ab70SNikolas Klauser           indirect_strict_weak_order<projected<const T*, Proj>> Comp = ranges::less>
19558d9ab70SNikolas Klauser    constexpr ranges::minmax_result<T>
19658d9ab70SNikolas Klauser      minmax(initializer_list<T> r, Comp comp = {}, Proj proj = {});                      // since C++20
19758d9ab70SNikolas Klauser
19858d9ab70SNikolas Klauser  template<input_range R, class Proj = identity,
19958d9ab70SNikolas Klauser           indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
20058d9ab70SNikolas Klauser    requires indirectly_copyable_storable<iterator_t<R>, range_value_t<R>*>
20158d9ab70SNikolas Klauser    constexpr ranges::minmax_result<range_value_t<R>>
20258d9ab70SNikolas Klauser      minmax(R&& r, Comp comp = {}, Proj proj = {});                                      // since C++20
20358d9ab70SNikolas Klauser
20479a2b4baSKonstantin Varlamov  template<class I>
20579a2b4baSKonstantin Varlamov  using minmax_element_result = min_max_result<I>;
20679a2b4baSKonstantin Varlamov
20758d9ab70SNikolas Klauser  template<forward_iterator I, sentinel_for<I> S, class Proj = identity,
20858d9ab70SNikolas Klauser           indirect_strict_weak_order<projected<I, Proj>> Comp = ranges::less>
20958d9ab70SNikolas Klauser    constexpr ranges::minmax_element_result<I>
21058d9ab70SNikolas Klauser      minmax_element(I first, S last, Comp comp = {}, Proj proj = {});                    // since C++20
21158d9ab70SNikolas Klauser
21258d9ab70SNikolas Klauser  template<forward_range R, class Proj = identity,
21358d9ab70SNikolas Klauser           indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
21458d9ab70SNikolas Klauser    constexpr ranges::minmax_element_result<borrowed_iterator_t<R>>
21558d9ab70SNikolas Klauser      minmax_element(R&& r, Comp comp = {}, Proj proj = {});                              // since C++20
2161d83750fSNikolas Klauser
2171d83750fSNikolas Klauser  template<class I, class O>
2181d83750fSNikolas Klauser    using copy_result = in_out_result<I, O>;                                              // since C++20
2191d83750fSNikolas Klauser
2201d83750fSNikolas Klauser  template<class I, class O>
2211d83750fSNikolas Klauser    using copy_n_result = in_out_result<I, O>;                                            // since C++20
2221d83750fSNikolas Klauser
2231d83750fSNikolas Klauser  template<class I, class O>
2241d83750fSNikolas Klauser    using copy_if_result = in_out_result<I, O>;                                             // since C++20
2251d83750fSNikolas Klauser
2261d83750fSNikolas Klauser  template<class I1, class I2>
2271d83750fSNikolas Klauser    using copy_backward_result = in_out_result<I1, I2>;                                     // since C++20
2281d83750fSNikolas Klauser
2291d83750fSNikolas Klauser  template<input_iterator I, sentinel_for<I> S, weakly_incrementable O>
2301d83750fSNikolas Klauser    requires indirectly_copyable<I, O>
2311d83750fSNikolas Klauser    constexpr ranges::copy_result<I, O> ranges::copy(I first, S last, O result);            // since C++20
2321d83750fSNikolas Klauser
2331d83750fSNikolas Klauser  template<input_range R, weakly_incrementable O>
2341d83750fSNikolas Klauser    requires indirectly_copyable<iterator_t<R>, O>
2351d83750fSNikolas Klauser    constexpr ranges::copy_result<borrowed_iterator_t<R>, O> ranges::copy(R&& r, O result); // since C++20
2361d83750fSNikolas Klauser
2371d83750fSNikolas Klauser  template<input_iterator I, weakly_incrementable O>
2381d83750fSNikolas Klauser    requires indirectly_copyable<I, O>
2391d83750fSNikolas Klauser    constexpr ranges::copy_n_result<I, O>
2401d83750fSNikolas Klauser      ranges::copy_n(I first, iter_difference_t<I> n, O result);                            // since C++20
2411d83750fSNikolas Klauser
2421d83750fSNikolas Klauser  template<input_iterator I, sentinel_for<I> S, weakly_incrementable O, class Proj = identity,
2431d83750fSNikolas Klauser           indirect_unary_predicate<projected<I, Proj>> Pred>
2441d83750fSNikolas Klauser    requires indirectly_copyable<I, O>
2451d83750fSNikolas Klauser    constexpr ranges::copy_if_result<I, O>
2461d83750fSNikolas Klauser      ranges::copy_if(I first, S last, O result, Pred pred, Proj proj = {});                // since C++20
2471d83750fSNikolas Klauser
2481d83750fSNikolas Klauser  template<input_range R, weakly_incrementable O, class Proj = identity,
2491d83750fSNikolas Klauser           indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
2501d83750fSNikolas Klauser    requires indirectly_copyable<iterator_t<R>, O>
2511d83750fSNikolas Klauser    constexpr ranges::copy_if_result<borrowed_iterator_t<R>, O>
2521d83750fSNikolas Klauser      ranges::copy_if(R&& r, O result, Pred pred, Proj proj = {});                          // since C++20
2531d83750fSNikolas Klauser
2541d83750fSNikolas Klauser  template<bidirectional_iterator I1, sentinel_for<I1> S1, bidirectional_iterator I2>
2551d83750fSNikolas Klauser    requires indirectly_copyable<I1, I2>
2561d83750fSNikolas Klauser    constexpr ranges::copy_backward_result<I1, I2>
2571d83750fSNikolas Klauser      ranges::copy_backward(I1 first, S1 last, I2 result);                                  // since C++20
2581d83750fSNikolas Klauser
2591d83750fSNikolas Klauser  template<bidirectional_range R, bidirectional_iterator I>
2601d83750fSNikolas Klauser    requires indirectly_copyable<iterator_t<R>, I>
2611d83750fSNikolas Klauser    constexpr ranges::copy_backward_result<borrowed_iterator_t<R>, I>
2621d83750fSNikolas Klauser      ranges::copy_backward(R&& r, I result);                                               // since C++20
26380045e9aSNikolas Klauser
26480045e9aSNikolas Klauser  template<class I, class F>
26580045e9aSNikolas Klauser    using for_each_result = in_fun_result<I, F>;                                            // since C++20
26680045e9aSNikolas Klauser
26780045e9aSNikolas Klauser  template<input_iterator I, sentinel_for<I> S, class Proj = identity,
26880045e9aSNikolas Klauser           indirectly_unary_invocable<projected<I, Proj>> Fun>
26980045e9aSNikolas Klauser    constexpr ranges::for_each_result<I, Fun>
27080045e9aSNikolas Klauser      ranges::for_each(I first, S last, Fun f, Proj proj = {});                             // since C++20
27180045e9aSNikolas Klauser
27280045e9aSNikolas Klauser  template<input_range R, class Proj = identity,
27380045e9aSNikolas Klauser           indirectly_unary_invocable<projected<iterator_t<R>, Proj>> Fun>
27480045e9aSNikolas Klauser    constexpr ranges::for_each_result<borrowed_iterator_t<R>, Fun>
27580045e9aSNikolas Klauser      ranges::for_each(R&& r, Fun f, Proj proj = {});                                       // since C++20
27680045e9aSNikolas Klauser
27780045e9aSNikolas Klauser  template<input_iterator I, class Proj = identity,
27880045e9aSNikolas Klauser           indirectly_unary_invocable<projected<I, Proj>> Fun>
27980045e9aSNikolas Klauser    constexpr ranges::for_each_n_result<I, Fun>
28080045e9aSNikolas Klauser      ranges::for_each_n(I first, iter_difference_t<I> n, Fun f, Proj proj = {});           // since C++20
28137ba1b9dSNikolas Klauser
28237ba1b9dSNikolas Klauser  template<input_iterator I, sentinel_for<I> S, class Proj = identity,
28337ba1b9dSNikolas Klauser           indirect_unary_predicate<projected<I, Proj>> Pred>
28437ba1b9dSNikolas Klauser    constexpr bool ranges::is_partitioned(I first, S last, Pred pred, Proj proj = {});      // since C++20
28537ba1b9dSNikolas Klauser
28637ba1b9dSNikolas Klauser  template<input_range R, class Proj = identity,
28737ba1b9dSNikolas Klauser           indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
28837ba1b9dSNikolas Klauser    constexpr bool ranges::is_partitioned(R&& r, Pred pred, Proj proj = {});                // since C++20
28937ba1b9dSNikolas Klauser
290c945bd0dSKonstantin Varlamov  template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
291c945bd0dSKonstantin Varlamov          class Proj = identity>
292c945bd0dSKonstantin Varlamov    requires sortable<I, Comp, Proj>
293c945bd0dSKonstantin Varlamov    constexpr I
294c945bd0dSKonstantin Varlamov      ranges::push_heap(I first, S last, Comp comp = {}, Proj proj = {});                   // since C++20
295c945bd0dSKonstantin Varlamov
296c945bd0dSKonstantin Varlamov  template<random_access_range R, class Comp = ranges::less, class Proj = identity>
297c945bd0dSKonstantin Varlamov    requires sortable<iterator_t<R>, Comp, Proj>
298c945bd0dSKonstantin Varlamov    constexpr borrowed_iterator_t<R>
299c945bd0dSKonstantin Varlamov      ranges::push_heap(R&& r, Comp comp = {}, Proj proj = {});                             // since C++20
300c945bd0dSKonstantin Varlamov
301c945bd0dSKonstantin Varlamov  template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
302c945bd0dSKonstantin Varlamov          class Proj = identity>
303c945bd0dSKonstantin Varlamov    requires sortable<I, Comp, Proj>
304c945bd0dSKonstantin Varlamov    constexpr I
305c945bd0dSKonstantin Varlamov      ranges::pop_heap(I first, S last, Comp comp = {}, Proj proj = {});                    // since C++20
306c945bd0dSKonstantin Varlamov
307c945bd0dSKonstantin Varlamov  template<random_access_range R, class Comp = ranges::less, class Proj = identity>
308c945bd0dSKonstantin Varlamov    requires sortable<iterator_t<R>, Comp, Proj>
309c945bd0dSKonstantin Varlamov    constexpr borrowed_iterator_t<R>
310c945bd0dSKonstantin Varlamov      ranges::pop_heap(R&& r, Comp comp = {}, Proj proj = {});                              // since C++20
311c945bd0dSKonstantin Varlamov
312c945bd0dSKonstantin Varlamov  template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
313c945bd0dSKonstantin Varlamov          class Proj = identity>
314c945bd0dSKonstantin Varlamov    requires sortable<I, Comp, Proj>
315c945bd0dSKonstantin Varlamov    constexpr I
316c945bd0dSKonstantin Varlamov      ranges::make_heap(I first, S last, Comp comp = {}, Proj proj = {});                   // since C++20
317c945bd0dSKonstantin Varlamov
318c945bd0dSKonstantin Varlamov  template<random_access_range R, class Comp = ranges::less, class Proj = identity>
319c945bd0dSKonstantin Varlamov    requires sortable<iterator_t<R>, Comp, Proj>
320c945bd0dSKonstantin Varlamov    constexpr borrowed_iterator_t<R>
321c945bd0dSKonstantin Varlamov      ranges::make_heap(R&& r, Comp comp = {}, Proj proj = {});                             // since C++20
322c945bd0dSKonstantin Varlamov
323c945bd0dSKonstantin Varlamov  template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
324c945bd0dSKonstantin Varlamov          class Proj = identity>
325c945bd0dSKonstantin Varlamov    requires sortable<I, Comp, Proj>
326c945bd0dSKonstantin Varlamov    constexpr I
327c945bd0dSKonstantin Varlamov      ranges::sort_heap(I first, S last, Comp comp = {}, Proj proj = {});                   // since C++20
328c945bd0dSKonstantin Varlamov
329c945bd0dSKonstantin Varlamov  template<random_access_range R, class Comp = ranges::less, class Proj = identity>
330c945bd0dSKonstantin Varlamov    requires sortable<iterator_t<R>, Comp, Proj>
331c945bd0dSKonstantin Varlamov    constexpr borrowed_iterator_t<R>
332c945bd0dSKonstantin Varlamov      ranges::sort_heap(R&& r, Comp comp = {}, Proj proj = {});                             // since C++20
333c945bd0dSKonstantin Varlamov
334d406c649SKonstantin Varlamov  template<random_access_iterator I, sentinel_for<I> S, class Proj = identity,
335d406c649SKonstantin Varlamov            indirect_strict_weak_order<projected<I, Proj>> Comp = ranges::less>
336d406c649SKonstantin Varlamov    constexpr bool is_heap(I first, S last, Comp comp = {}, Proj proj = {});                // Since C++20
337d406c649SKonstantin Varlamov
338d406c649SKonstantin Varlamov  template<random_access_range R, class Proj = identity,
339d406c649SKonstantin Varlamov            indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
340d406c649SKonstantin Varlamov    constexpr bool is_heap(R&& r, Comp comp = {}, Proj proj = {});                          // Since C++20
341d406c649SKonstantin Varlamov
342d406c649SKonstantin Varlamov  template<random_access_iterator I, sentinel_for<I> S, class Proj = identity,
343d406c649SKonstantin Varlamov           indirect_strict_weak_order<projected<I, Proj>> Comp = ranges::less>
344d406c649SKonstantin Varlamov    constexpr I is_heap_until(I first, S last, Comp comp = {}, Proj proj = {});             // Since C++20
345d406c649SKonstantin Varlamov
346d406c649SKonstantin Varlamov  template<random_access_range R, class Proj = identity,
347d406c649SKonstantin Varlamov           indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
348d406c649SKonstantin Varlamov    constexpr borrowed_iterator_t<R>
349d406c649SKonstantin Varlamov      is_heap_until(R&& r, Comp comp = {}, Proj proj = {});                                 // Since C++20
350d406c649SKonstantin Varlamov
3511d1a191eSNikolas Klauser  template<bidirectional_iterator I, sentinel_for<I> S>
3521d1a191eSNikolas Klauser    requires permutable<I>
3531d1a191eSNikolas Klauser    constexpr I ranges::reverse(I first, S last);                                           // since C++20
3541d1a191eSNikolas Klauser
3551d1a191eSNikolas Klauser  template<bidirectional_range R>
3561d1a191eSNikolas Klauser    requires permutable<iterator_t<R>>
3571d1a191eSNikolas Klauser    constexpr borrowed_iterator_t<R> ranges::reverse(R&& r);                                // since C++20
3581d1a191eSNikolas Klauser
359ff3989e6SKonstantin Varlamov  template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
360ff3989e6SKonstantin Varlamov            class Proj = identity>
361ff3989e6SKonstantin Varlamov    requires sortable<I, Comp, Proj>
362ff3989e6SKonstantin Varlamov    constexpr I
36394c7b89fSKonstantin Varlamov      ranges::sort(I first, S last, Comp comp = {}, Proj proj = {});                        // since C++20
364ff3989e6SKonstantin Varlamov
365ff3989e6SKonstantin Varlamov  template<random_access_range R, class Comp = ranges::less, class Proj = identity>
366ff3989e6SKonstantin Varlamov    requires sortable<iterator_t<R>, Comp, Proj>
367ff3989e6SKonstantin Varlamov    constexpr borrowed_iterator_t<R>
36894c7b89fSKonstantin Varlamov      ranges::sort(R&& r, Comp comp = {}, Proj proj = {});                                  // since C++20
36994c7b89fSKonstantin Varlamov
37094c7b89fSKonstantin Varlamov  template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
37194c7b89fSKonstantin Varlamov          class Proj = identity>
37294c7b89fSKonstantin Varlamov    requires sortable<I, Comp, Proj>
37394c7b89fSKonstantin Varlamov    I ranges::stable_sort(I first, S last, Comp comp = {}, Proj proj = {});                 // since C++20
37494c7b89fSKonstantin Varlamov
37594c7b89fSKonstantin Varlamov  template<random_access_range R, class Comp = ranges::less, class Proj = identity>
37694c7b89fSKonstantin Varlamov    requires sortable<iterator_t<R>, Comp, Proj>
37794c7b89fSKonstantin Varlamov    borrowed_iterator_t<R>
37894c7b89fSKonstantin Varlamov      ranges::stable_sort(R&& r, Comp comp = {}, Proj proj = {});                           // since C++20
379ff3989e6SKonstantin Varlamov
3805dd19adaSvarconst  template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
3815dd19adaSvarconst           class Proj = identity>
3825dd19adaSvarconst    requires sortable<I, Comp, Proj>
3835dd19adaSvarconst    constexpr I
3845dd19adaSvarconst      ranges::partial_sort(I first, I middle, S last, Comp comp = {}, Proj proj = {});      // since C++20
3855dd19adaSvarconst
3865dd19adaSvarconst  template<random_access_range R, class Comp = ranges::less, class Proj = identity>
3875dd19adaSvarconst    requires sortable<iterator_t<R>, Comp, Proj>
3885dd19adaSvarconst    constexpr borrowed_iterator_t<R>
3895dd19adaSvarconst      ranges::partial_sort(R&& r, iterator_t<R> middle, Comp comp = {}, Proj proj = {});    // since C++20
3905dd19adaSvarconst
3917af89a37SNikolas Klauser  template<class T, output_iterator<const T&> O, sentinel_for<O> S>
3927af89a37SNikolas Klauser    constexpr O ranges::fill(O first, S last, const T& value);                              // since C++20
3937af89a37SNikolas Klauser
3947af89a37SNikolas Klauser  template<class T, output_range<const T&> R>
3957af89a37SNikolas Klauser    constexpr borrowed_iterator_t<R> ranges::fill(R&& r, const T& value);                   // since C++20
3967af89a37SNikolas Klauser
3977af89a37SNikolas Klauser  template<class T, output_iterator<const T&> O>
3987af89a37SNikolas Klauser    constexpr O ranges::fill_n(O first, iter_difference_t<O> n, const T& value);            // since C++20
399569d6630SNikolas Klauser
400ead7302bSKonstantin Varlamov  template<input_or_output_iterator O, sentinel_for<O> S, copy_constructible F>
401ead7302bSKonstantin Varlamov    requires invocable<F&> && indirectly_writable<O, invoke_result_t<F&>>
402ead7302bSKonstantin Varlamov    constexpr O generate(O first, S last, F gen);                                           // Since C++20
403ead7302bSKonstantin Varlamov
404ead7302bSKonstantin Varlamov  template<class R, copy_constructible F>
405ead7302bSKonstantin Varlamov    requires invocable<F&> && output_range<R, invoke_result_t<F&>>
406ead7302bSKonstantin Varlamov    constexpr borrowed_iterator_t<R> generate(R&& r, F gen);                                // Since C++20
407ead7302bSKonstantin Varlamov
408ead7302bSKonstantin Varlamov  template<input_or_output_iterator O, copy_constructible F>
409ead7302bSKonstantin Varlamov    requires invocable<F&> && indirectly_writable<O, invoke_result_t<F&>>
410ead7302bSKonstantin Varlamov    constexpr O generate_n(O first, iter_difference_t<O> n, F gen);                         // Since C++20
411ead7302bSKonstantin Varlamov
412569d6630SNikolas Klauser template<input_iterator I1, sentinel_for<I1> S1, input_iterator I2, sentinel_for<I2> S2,
413569d6630SNikolas Klauser          class Pred = ranges::equal_to, class Proj1 = identity, class Proj2 = identity>
414569d6630SNikolas Klauser   requires indirectly_comparable<I1, I2, Pred, Proj1, Proj2>
415569d6630SNikolas Klauser   constexpr bool ranges::equal(I1 first1, S1 last1, I2 first2, S2 last2,
416569d6630SNikolas Klauser                                Pred pred = {},
417569d6630SNikolas Klauser                                Proj1 proj1 = {}, Proj2 proj2 = {});                        // since C++20
418569d6630SNikolas Klauser
419569d6630SNikolas Klauser template<input_range R1, input_range R2, class Pred = ranges::equal_to,
420569d6630SNikolas Klauser          class Proj1 = identity, class Proj2 = identity>
421569d6630SNikolas Klauser   requires indirectly_comparable<iterator_t<R1>, iterator_t<R2>, Pred, Proj1, Proj2>
422569d6630SNikolas Klauser   constexpr bool ranges::equal(R1&& r1, R2&& r2, Pred pred = {},
423569d6630SNikolas Klauser                                Proj1 proj1 = {}, Proj2 proj2 = {});                        // since C++20
424569d6630SNikolas Klauser
4250e3dc1a5SNikolas Klauser  template<input_iterator I, sentinel_for<I> S, class Proj = identity,
4260e3dc1a5SNikolas Klauser           indirect_unary_predicate<projected<I, Proj>> Pred>
4270e3dc1a5SNikolas Klauser    constexpr bool ranges::all_of(I first, S last, Pred pred, Proj proj = {});      // since C++20
4280e3dc1a5SNikolas Klauser
4290e3dc1a5SNikolas Klauser  template<input_range R, class Proj = identity,
4300e3dc1a5SNikolas Klauser           indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
4310e3dc1a5SNikolas Klauser    constexpr bool ranges::all_of(R&& r, Pred pred, Proj proj = {});                // since C++20
4320e3dc1a5SNikolas Klauser
4330e3dc1a5SNikolas Klauser  template<input_iterator I, sentinel_for<I> S, class Proj = identity,
4340e3dc1a5SNikolas Klauser           indirect_unary_predicate<projected<I, Proj>> Pred>
4350e3dc1a5SNikolas Klauser    constexpr bool ranges::any_of(I first, S last, Pred pred, Proj proj = {});      // since C++20
4360e3dc1a5SNikolas Klauser
4370e3dc1a5SNikolas Klauser  template<input_range R, class Proj = identity,
4380e3dc1a5SNikolas Klauser           indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
4390e3dc1a5SNikolas Klauser    constexpr bool ranges::any_of(R&& r, Pred pred, Proj proj = {});                // since C++20
4400e3dc1a5SNikolas Klauser
4410e3dc1a5SNikolas Klauser  template<input_iterator I, sentinel_for<I> S, class Proj = identity,
4420e3dc1a5SNikolas Klauser           indirect_unary_predicate<projected<I, Proj>> Pred>
4430e3dc1a5SNikolas Klauser    constexpr bool ranges::none_of(I first, S last, Pred pred, Proj proj = {});     // since C++20
4440e3dc1a5SNikolas Klauser
4450e3dc1a5SNikolas Klauser  template<input_range R, class Proj = identity,
4460e3dc1a5SNikolas Klauser           indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
4470e3dc1a5SNikolas Klauser    constexpr bool ranges::none_of(R&& r, Pred pred, Proj proj = {});               // since C++20
4480e3dc1a5SNikolas Klauser
4492c766efcSKonstantin Varlamov  template<input_iterator I1, sentinel_for<I1> S1,
4502c766efcSKonstantin Varlamov          random_access_iterator I2, sentinel_for<I2> S2,
4512c766efcSKonstantin Varlamov          class Comp = ranges::less, class Proj1 = identity, class Proj2 = identity>
4522c766efcSKonstantin Varlamov    requires indirectly_copyable<I1, I2> && sortable<I2, Comp, Proj2> &&
4532c766efcSKonstantin Varlamov            indirect_strict_weak_order<Comp, projected<I1, Proj1>, projected<I2, Proj2>>
4542c766efcSKonstantin Varlamov    constexpr partial_sort_copy_result<I1, I2>
4552c766efcSKonstantin Varlamov      partial_sort_copy(I1 first, S1 last, I2 result_first, S2 result_last,
4562c766efcSKonstantin Varlamov                        Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});        // Since C++20
4572c766efcSKonstantin Varlamov
4582c766efcSKonstantin Varlamov  template<input_range R1, random_access_range R2, class Comp = ranges::less,
4592c766efcSKonstantin Varlamov          class Proj1 = identity, class Proj2 = identity>
4602c766efcSKonstantin Varlamov    requires indirectly_copyable<iterator_t<R1>, iterator_t<R2>> &&
4612c766efcSKonstantin Varlamov            sortable<iterator_t<R2>, Comp, Proj2> &&
4622c766efcSKonstantin Varlamov            indirect_strict_weak_order<Comp, projected<iterator_t<R1>, Proj1>,
4632c766efcSKonstantin Varlamov                                        projected<iterator_t<R2>, Proj2>>
4642c766efcSKonstantin Varlamov    constexpr partial_sort_copy_result<borrowed_iterator_t<R1>, borrowed_iterator_t<R2>>
4652c766efcSKonstantin Varlamov      partial_sort_copy(R1&& r, R2&& result_r, Comp comp = {},
4662c766efcSKonstantin Varlamov                        Proj1 proj1 = {}, Proj2 proj2 = {});                        // Since C++20
4672c766efcSKonstantin Varlamov
46811e3ad29SNikolas Klauser  template<forward_iterator I, sentinel_for<I> S, class Proj = identity,
46911e3ad29SNikolas Klauser           indirect_strict_weak_order<projected<I, Proj>> Comp = ranges::less>
47011e3ad29SNikolas Klauser    constexpr bool ranges::is_sorted(I first, S last, Comp comp = {}, Proj proj = {});      // since C++20
47111e3ad29SNikolas Klauser
47211e3ad29SNikolas Klauser  template<forward_range R, class Proj = identity,
47311e3ad29SNikolas Klauser           indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
47411e3ad29SNikolas Klauser    constexpr bool ranges::is_sorted(R&& r, Comp comp = {}, Proj proj = {});                // since C++20
47511e3ad29SNikolas Klauser
47611e3ad29SNikolas Klauser  template<forward_iterator I, sentinel_for<I> S, class Proj = identity,
47711e3ad29SNikolas Klauser           indirect_strict_weak_order<projected<I, Proj>> Comp = ranges::less>
47811e3ad29SNikolas Klauser    constexpr I ranges::is_sorted_until(I first, S last, Comp comp = {}, Proj proj = {});   // since C++20
47911e3ad29SNikolas Klauser
48011e3ad29SNikolas Klauser  template<forward_range R, class Proj = identity,
48111e3ad29SNikolas Klauser           indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
48211e3ad29SNikolas Klauser    constexpr borrowed_iterator_t<R>
48311e3ad29SNikolas Klauser      ranges::is_sorted_until(R&& r, Comp comp = {}, Proj proj = {});                       // since C++20
48481715861SNikolas Klauser
48523c7328bSKonstantin Varlamov  template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
48623c7328bSKonstantin Varlamov          class Proj = identity>
48723c7328bSKonstantin Varlamov    requires sortable<I, Comp, Proj>
48823c7328bSKonstantin Varlamov    constexpr I
48923c7328bSKonstantin Varlamov      ranges::nth_element(I first, I nth, S last, Comp comp = {}, Proj proj = {});            // since C++20
49023c7328bSKonstantin Varlamov
49123c7328bSKonstantin Varlamov  template<random_access_range R, class Comp = ranges::less, class Proj = identity>
49223c7328bSKonstantin Varlamov    requires sortable<iterator_t<R>, Comp, Proj>
49323c7328bSKonstantin Varlamov    constexpr borrowed_iterator_t<R>
49423c7328bSKonstantin Varlamov      ranges::nth_element(R&& r, iterator_t<R> nth, Comp comp = {}, Proj proj = {});          // since C++20
49523c7328bSKonstantin Varlamov
49681715861SNikolas Klauser  template<forward_iterator I, sentinel_for<I> S, class T, class Proj = identity,
49781715861SNikolas Klauser           indirect_strict_weak_order<const T*, projected<I, Proj>> Comp = ranges::less>
49881715861SNikolas Klauser    constexpr I upper_bound(I first, S last, const T& value, Comp comp = {}, Proj proj = {}); // since C++20
49981715861SNikolas Klauser
50081715861SNikolas Klauser  template<forward_range R, class T, class Proj = identity,
50181715861SNikolas Klauser           indirect_strict_weak_order<const T*, projected<iterator_t<R>, Proj>> Comp =
50281715861SNikolas Klauser             ranges::less>
50381715861SNikolas Klauser    constexpr borrowed_iterator_t<R>
50481715861SNikolas Klauser      upper_bound(R&& r, const T& value, Comp comp = {}, Proj proj = {});                     // since C++20
50581715861SNikolas Klauser
50681715861SNikolas Klauser  template<forward_iterator I, sentinel_for<I> S, class T, class Proj = identity,
50781715861SNikolas Klauser           indirect_strict_weak_order<const T*, projected<I, Proj>> Comp = ranges::less>
50881715861SNikolas Klauser    constexpr I lower_bound(I first, S last, const T& value, Comp comp = {},
50981715861SNikolas Klauser                                    Proj proj = {});                                          // since C++20
51081715861SNikolas Klauser  template<forward_range R, class T, class Proj = identity,
51181715861SNikolas Klauser           indirect_strict_weak_order<const T*, projected<iterator_t<R>, Proj>> Comp =
51281715861SNikolas Klauser             ranges::less>
51381715861SNikolas Klauser    constexpr borrowed_iterator_t<R>
51481715861SNikolas Klauser      lower_bound(R&& r, const T& value, Comp comp = {}, Proj proj = {});                     // since C++20
51581715861SNikolas Klauser
51681715861SNikolas Klauser  template<forward_iterator I, sentinel_for<I> S, class T, class Proj = identity,
51781715861SNikolas Klauser           indirect_strict_weak_order<const T*, projected<I, Proj>> Comp = ranges::less>
51881715861SNikolas Klauser    constexpr bool binary_search(I first, S last, const T& value, Comp comp = {},
51981715861SNikolas Klauser                                         Proj proj = {});                                     // since C++20
520b79b2b67SNikolas Klauser
52181715861SNikolas Klauser  template<forward_range R, class T, class Proj = identity,
52281715861SNikolas Klauser           indirect_strict_weak_order<const T*, projected<iterator_t<R>, Proj>> Comp =
52381715861SNikolas Klauser             ranges::less>
52481715861SNikolas Klauser    constexpr bool binary_search(R&& r, const T& value, Comp comp = {},
52581715861SNikolas Klauser                                         Proj proj = {});                                     // since C++20
5268ed702b8SKonstantin Varlamov
5278ed702b8SKonstantin Varlamov  template<permutable I, sentinel_for<I> S, class Proj = identity,
5288ed702b8SKonstantin Varlamov           indirect_unary_predicate<projected<I, Proj>> Pred>
5298ed702b8SKonstantin Varlamov    constexpr subrange<I>
5308ed702b8SKonstantin Varlamov      partition(I first, S last, Pred pred, Proj proj = {});                                  // Since C++20
5318ed702b8SKonstantin Varlamov
5328ed702b8SKonstantin Varlamov  template<forward_range R, class Proj = identity,
5338ed702b8SKonstantin Varlamov           indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
5348ed702b8SKonstantin Varlamov    requires permutable<iterator_t<R>>
5358ed702b8SKonstantin Varlamov    constexpr borrowed_subrange_t<R>
5368ed702b8SKonstantin Varlamov      partition(R&& r, Pred pred, Proj proj = {});                                            // Since C++20
5378ed702b8SKonstantin Varlamov
5388ed702b8SKonstantin Varlamov  template<bidirectional_iterator I, sentinel_for<I> S, class Proj = identity,
5398ed702b8SKonstantin Varlamov           indirect_unary_predicate<projected<I, Proj>> Pred>
5408ed702b8SKonstantin Varlamov    requires permutable<I>
5418ed702b8SKonstantin Varlamov    subrange<I> stable_partition(I first, S last, Pred pred, Proj proj = {});                 // Since C++20
5428ed702b8SKonstantin Varlamov
5438ed702b8SKonstantin Varlamov  template<bidirectional_range R, class Proj = identity,
5448ed702b8SKonstantin Varlamov           indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
5458ed702b8SKonstantin Varlamov    requires permutable<iterator_t<R>>
5468ed702b8SKonstantin Varlamov    borrowed_subrange_t<R> stable_partition(R&& r, Pred pred, Proj proj = {});                // Since C++20
5478ed702b8SKonstantin Varlamov
548b79b2b67SNikolas Klauser  template<input_iterator I1, sentinel_for<I1> S1, forward_iterator I2, sentinel_for<I2> S2,
549b79b2b67SNikolas Klauser           class Pred = ranges::equal_to, class Proj1 = identity, class Proj2 = identity>
550b79b2b67SNikolas Klauser    requires indirectly_comparable<I1, I2, Pred, Proj1, Proj2>
551b79b2b67SNikolas Klauser    constexpr I1 ranges::find_first_of(I1 first1, S1 last1, I2 first2, S2 last2,
552b79b2b67SNikolas Klauser                                       Pred pred = {},
553b79b2b67SNikolas Klauser                                       Proj1 proj1 = {}, Proj2 proj2 = {});                 // since C++20
554b79b2b67SNikolas Klauser
555b79b2b67SNikolas Klauser  template<input_range R1, forward_range R2,
556b79b2b67SNikolas Klauser           class Pred = ranges::equal_to, class Proj1 = identity, class Proj2 = identity>
557b79b2b67SNikolas Klauser    requires indirectly_comparable<iterator_t<R1>, iterator_t<R2>, Pred, Proj1, Proj2>
558b79b2b67SNikolas Klauser    constexpr borrowed_iterator_t<R1>
559b79b2b67SNikolas Klauser      ranges::find_first_of(R1&& r1, R2&& r2,
560b79b2b67SNikolas Klauser                            Pred pred = {},
561b79b2b67SNikolas Klauser                            Proj1 proj1 = {}, Proj2 proj2 = {});                            // since C++20
56281715861SNikolas Klauser
563916e9052SNikolas Klauser  template<forward_iterator I, sentinel_for<I> S, class Proj = identity,
564916e9052SNikolas Klauser           indirect_binary_predicate<projected<I, Proj>,
565916e9052SNikolas Klauser                                     projected<I, Proj>> Pred = ranges::equal_to>
566916e9052SNikolas Klauser    constexpr I ranges::adjacent_find(I first, S last, Pred pred = {}, Proj proj = {});     // since C+20
567916e9052SNikolas Klauser
568916e9052SNikolas Klauser  template<forward_range R, class Proj = identity,
569916e9052SNikolas Klauser           indirect_binary_predicate<projected<iterator_t<R>, Proj>,
570916e9052SNikolas Klauser                                     projected<iterator_t<R>, Proj>> Pred = ranges::equal_to>
571916e9052SNikolas Klauser    constexpr borrowed_iterator_t<R> ranges::adjacent_find(R&& r, Pred pred = {}, Proj proj = {});  // since C++20
572916e9052SNikolas Klauser
573ff6d5deeSNikolas Klauser  template<input_iterator I, sentinel_for<I> S, class T1, class T2, class Proj = identity>
574ff6d5deeSNikolas Klauser    requires indirectly_writable<I, const T2&> &&
575ff6d5deeSNikolas Klauser             indirect_binary_predicate<ranges::equal_to, projected<I, Proj>, const T1*>
576ff6d5deeSNikolas Klauser    constexpr I
577ff6d5deeSNikolas Klauser      ranges::replace(I first, S last, const T1& old_value, const T2& new_value, Proj proj = {});   // since C++20
578ff6d5deeSNikolas Klauser
579ff6d5deeSNikolas Klauser  template<input_range R, class T1, class T2, class Proj = identity>
580ff6d5deeSNikolas Klauser    requires indirectly_writable<iterator_t<R>, const T2&> &&
581ff6d5deeSNikolas Klauser             indirect_binary_predicate<ranges::equal_to, projected<iterator_t<R>, Proj>, const T1*>
582ff6d5deeSNikolas Klauser    constexpr borrowed_iterator_t<R>
583ff6d5deeSNikolas Klauser      ranges::replace(R&& r, const T1& old_value, const T2& new_value, Proj proj = {});             // since C++20
584ff6d5deeSNikolas Klauser
585ff6d5deeSNikolas Klauser  template<input_iterator I, sentinel_for<I> S, class T, class Proj = identity,
586ff6d5deeSNikolas Klauser           indirect_unary_predicate<projected<I, Proj>> Pred>
587ff6d5deeSNikolas Klauser    requires indirectly_writable<I, const T&>
588ff6d5deeSNikolas Klauser    constexpr I ranges::replace_if(I first, S last, Pred pred, const T& new_value, Proj proj = {}); // since C++20
589ff6d5deeSNikolas Klauser
590ff6d5deeSNikolas Klauser  template<input_range R, class T, class Proj = identity,
591ff6d5deeSNikolas Klauser           indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
592ff6d5deeSNikolas Klauser    requires indirectly_writable<iterator_t<R>, const T&>
593ff6d5deeSNikolas Klauser    constexpr borrowed_iterator_t<R>
594ff6d5deeSNikolas Klauser      ranges::replace_if(R&& r, Pred pred, const T& new_value, Proj proj = {});                     // since C++20
595ff6d5deeSNikolas Klauser
596f20566daSNikolas Klauser  template<class T, class Proj = identity,
597f20566daSNikolas Klauser           indirect_strict_weak_order<projected<const T*, Proj>> Comp = ranges::less>
598f20566daSNikolas Klauser    constexpr const T&
599f20566daSNikolas Klauser      ranges::clamp(const T& v, const T& lo, const T& hi, Comp comp = {}, Proj proj = {});          // since C++20
600f20566daSNikolas Klauser
601afd5a4f2SNikolas Klauser  template<input_iterator I1, sentinel_for<I1> S1, input_iterator I2, sentinel_for<I2> S2,
602afd5a4f2SNikolas Klauser           class Proj1 = identity, class Proj2 = identity,
603afd5a4f2SNikolas Klauser           indirect_strict_weak_order<projected<I1, Proj1>,
604afd5a4f2SNikolas Klauser                                      projected<I2, Proj2>> Comp = ranges::less>
605afd5a4f2SNikolas Klauser    constexpr bool
606afd5a4f2SNikolas Klauser      ranges::lexicographical_compare(I1 first1, S1 last1, I2 first2, S2 last2,
607afd5a4f2SNikolas Klauser                                      Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});    // since C++20
608afd5a4f2SNikolas Klauser
609afd5a4f2SNikolas Klauser  template<input_range R1, input_range R2, class Proj1 = identity,
610afd5a4f2SNikolas Klauser           class Proj2 = identity,
611afd5a4f2SNikolas Klauser           indirect_strict_weak_order<projected<iterator_t<R1>, Proj1>,
612afd5a4f2SNikolas Klauser                                      projected<iterator_t<R2>, Proj2>> Comp = ranges::less>
613afd5a4f2SNikolas Klauser    constexpr bool
614afd5a4f2SNikolas Klauser      ranges::lexicographical_compare(R1&& r1, R2&& r2, Comp comp = {},
615afd5a4f2SNikolas Klauser                                      Proj1 proj1 = {}, Proj2 proj2 = {});                    // since C++20
616afd5a4f2SNikolas Klauser
6172c3bbac0SNikolas Klauser  template<bidirectional_iterator I1, sentinel_for<I1> S1, bidirectional_iterator I2>
6182c3bbac0SNikolas Klauser    requires indirectly_movable<I1, I2>
6192c3bbac0SNikolas Klauser    constexpr ranges::move_backward_result<I1, I2>
6202c3bbac0SNikolas Klauser      ranges::move_backward(I1 first, S1 last, I2 result);                                          // since C++20
6212c3bbac0SNikolas Klauser
6222c3bbac0SNikolas Klauser  template<bidirectional_range R, bidirectional_iterator I>
6232c3bbac0SNikolas Klauser    requires indirectly_movable<iterator_t<R>, I>
6242c3bbac0SNikolas Klauser    constexpr ranges::move_backward_result<borrowed_iterator_t<R>, I>
6252c3bbac0SNikolas Klauser      ranges::move_backward(R&& r, I result);                                                       // since C++20
6262c3bbac0SNikolas Klauser
6272c3bbac0SNikolas Klauser  template<input_iterator I, sentinel_for<I> S, weakly_incrementable O>
6282c3bbac0SNikolas Klauser    requires indirectly_movable<I, O>
6292c3bbac0SNikolas Klauser    constexpr ranges::move_result<I, O>
6302c3bbac0SNikolas Klauser      ranges::move(I first, S last, O result);                                                      // since C++20
6312c3bbac0SNikolas Klauser
6322c3bbac0SNikolas Klauser  template<input_range R, weakly_incrementable O>
6332c3bbac0SNikolas Klauser    requires indirectly_movable<iterator_t<R>, O>
6342c3bbac0SNikolas Klauser    constexpr ranges::move_result<borrowed_iterator_t<R>, O>
6352c3bbac0SNikolas Klauser      ranges::move(R&& r, O result);                                                                // since C++20
6362c3bbac0SNikolas Klauser
637065202f3SKonstantin Varlamov  template<class I, class O1, class O2>
638065202f3SKonstantin Varlamov      using partition_copy_result = in_out_out_result<I, O1, O2>;                                   // since C++20
639065202f3SKonstantin Varlamov
640065202f3SKonstantin Varlamov  template<input_iterator I, sentinel_for<I> S,
641065202f3SKonstantin Varlamov          weakly_incrementable O1, weakly_incrementable O2,
642065202f3SKonstantin Varlamov          class Proj = identity, indirect_unary_predicate<projected<I, Proj>> Pred>
643065202f3SKonstantin Varlamov    requires indirectly_copyable<I, O1> && indirectly_copyable<I, O2>
644065202f3SKonstantin Varlamov    constexpr partition_copy_result<I, O1, O2>
645065202f3SKonstantin Varlamov      partition_copy(I first, S last, O1 out_true, O2 out_false, Pred pred,
646065202f3SKonstantin Varlamov                    Proj proj = {});                                                                // Since C++20
647065202f3SKonstantin Varlamov
648065202f3SKonstantin Varlamov  template<input_range R, weakly_incrementable O1, weakly_incrementable O2,
649065202f3SKonstantin Varlamov          class Proj = identity,
650065202f3SKonstantin Varlamov          indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
651065202f3SKonstantin Varlamov    requires indirectly_copyable<iterator_t<R>, O1> &&
652065202f3SKonstantin Varlamov            indirectly_copyable<iterator_t<R>, O2>
653065202f3SKonstantin Varlamov    constexpr partition_copy_result<borrowed_iterator_t<R>, O1, O2>
654065202f3SKonstantin Varlamov      partition_copy(R&& r, O1 out_true, O2 out_false, Pred pred, Proj proj = {});                  // Since C++20
655065202f3SKonstantin Varlamov
656065202f3SKonstantin Varlamov  template<forward_iterator I, sentinel_for<I> S, class Proj = identity,
657065202f3SKonstantin Varlamov           indirect_unary_predicate<projected<I, Proj>> Pred>
658065202f3SKonstantin Varlamov    constexpr I partition_point(I first, S last, Pred pred, Proj proj = {});                        // Since C++20
659065202f3SKonstantin Varlamov
660065202f3SKonstantin Varlamov  template<forward_range R, class Proj = identity,
661065202f3SKonstantin Varlamov           indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
662065202f3SKonstantin Varlamov    constexpr borrowed_iterator_t<R>
663065202f3SKonstantin Varlamov      partition_point(R&& r, Pred pred, Proj proj = {});                                            // Since C++20
664065202f3SKonstantin Varlamov
66525607d14SHui Xie  template<class I1, class I2, class O>
66625607d14SHui Xie    using merge_result = in_in_out_result<I1, I2, O>;                                               // since C++20
66725607d14SHui Xie
66825607d14SHui Xie  template<input_iterator I1, sentinel_for<I1> S1, input_iterator I2, sentinel_for<I2> S2,
66925607d14SHui Xie           weakly_incrementable O, class Comp = ranges::less, class Proj1 = identity,
67025607d14SHui Xie           class Proj2 = identity>
67125607d14SHui Xie    requires mergeable<I1, I2, O, Comp, Proj1, Proj2>
67225607d14SHui Xie    constexpr merge_result<I1, I2, O>
67325607d14SHui Xie      merge(I1 first1, S1 last1, I2 first2, S2 last2, O result,
67425607d14SHui Xie            Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});                                    // since C++20
67525607d14SHui Xie
67625607d14SHui Xie  template<input_range R1, input_range R2, weakly_incrementable O, class Comp = ranges::less,
67725607d14SHui Xie           class Proj1 = identity, class Proj2 = identity>
67825607d14SHui Xie    requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
67925607d14SHui Xie    constexpr merge_result<borrowed_iterator_t<R1>, borrowed_iterator_t<R2>, O>
68025607d14SHui Xie      merge(R1&& r1, R2&& r2, O result,
68125607d14SHui Xie            Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});                                    // since C++20
6822c3bbac0SNikolas Klauser
683f8cbe3cdSNikolas Klauser  template<permutable I, sentinel_for<I> S, class T, class Proj = identity>
684f8cbe3cdSNikolas Klauser    requires indirect_binary_predicate<ranges::equal_to, projected<I, Proj>, const T*>
685f8cbe3cdSNikolas Klauser    constexpr subrange<I> ranges::remove(I first, S last, const T& value, Proj proj = {});          // since C++20
686f8cbe3cdSNikolas Klauser
687f8cbe3cdSNikolas Klauser  template<forward_range R, class T, class Proj = identity>
688f8cbe3cdSNikolas Klauser    requires permutable<iterator_t<R>> &&
689f8cbe3cdSNikolas Klauser             indirect_binary_predicate<ranges::equal_to, projected<iterator_t<R>, Proj>, const T*>
690f8cbe3cdSNikolas Klauser    constexpr borrowed_subrange_t<R>
691f8cbe3cdSNikolas Klauser      ranges::remove(R&& r, const T& value, Proj proj = {});                                        // since C++20
692f8cbe3cdSNikolas Klauser
693f8cbe3cdSNikolas Klauser  template<permutable I, sentinel_for<I> S, class Proj = identity,
694f8cbe3cdSNikolas Klauser           indirect_unary_predicate<projected<I, Proj>> Pred>
695f8cbe3cdSNikolas Klauser    constexpr subrange<I> ranges::remove_if(I first, S last, Pred pred, Proj proj = {});            // since C++20
696f8cbe3cdSNikolas Klauser
697f8cbe3cdSNikolas Klauser  template<forward_range R, class Proj = identity,
698f8cbe3cdSNikolas Klauser           indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
699f8cbe3cdSNikolas Klauser    requires permutable<iterator_t<R>>
700f8cbe3cdSNikolas Klauser    constexpr borrowed_subrange_t<R>
701f8cbe3cdSNikolas Klauser      ranges::remove_if(R&& r, Pred pred, Proj proj = {});                                          // since C++20
702f8cbe3cdSNikolas Klauser
7031cdec6c9SHui Xie  template<class I, class O>
7041cdec6c9SHui Xie    using set_difference_result = in_out_result<I, O>;                                              // since C++20
7051cdec6c9SHui Xie
7061cdec6c9SHui Xie  template<input_iterator I1, sentinel_for<I1> S1, input_iterator I2, sentinel_for<I2> S2,
7071cdec6c9SHui Xie           weakly_incrementable O, class Comp = ranges::less,
7081cdec6c9SHui Xie           class Proj1 = identity, class Proj2 = identity>
7091cdec6c9SHui Xie    requires mergeable<I1, I2, O, Comp, Proj1, Proj2>
7101cdec6c9SHui Xie    constexpr set_difference_result<I1, O>
7111cdec6c9SHui Xie      set_difference(I1 first1, S1 last1, I2 first2, S2 last2, O result,
7121cdec6c9SHui Xie                     Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});                           // since C++20
7131cdec6c9SHui Xie
7141cdec6c9SHui Xie  template<input_range R1, input_range R2, weakly_incrementable O,
7151cdec6c9SHui Xie           class Comp = ranges::less, class Proj1 = identity, class Proj2 = identity>
7161cdec6c9SHui Xie    requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
7171cdec6c9SHui Xie    constexpr set_difference_result<borrowed_iterator_t<R1>, O>
7181cdec6c9SHui Xie      set_difference(R1&& r1, R2&& r2, O result,
7191cdec6c9SHui Xie                     Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});                           // since C++20
7201cdec6c9SHui Xie
72196b674f2SHui Xie  template<class I1, class I2, class O>
72296b674f2SHui Xie    using set_intersection_result = in_in_out_result<I1, I2, O>;                                    // since C++20
72396b674f2SHui Xie
72496b674f2SHui Xie  template<input_iterator I1, sentinel_for<I1> S1, input_iterator I2, sentinel_for<I2> S2,
72596b674f2SHui Xie           weakly_incrementable O, class Comp = ranges::less,
72696b674f2SHui Xie           class Proj1 = identity, class Proj2 = identity>
72796b674f2SHui Xie    requires mergeable<I1, I2, O, Comp, Proj1, Proj2>
72896b674f2SHui Xie    constexpr set_intersection_result<I1, I2, O>
72996b674f2SHui Xie      set_intersection(I1 first1, S1 last1, I2 first2, S2 last2, O result,
73096b674f2SHui Xie                       Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});                         // since C++20
73196b674f2SHui Xie
73296b674f2SHui Xie  template<input_iterator I1, sentinel_for<I1> S1, input_iterator I2, sentinel_for<I2> S2,
73396b674f2SHui Xie           weakly_incrementable O, class Comp = ranges::less,
73496b674f2SHui Xie           class Proj1 = identity, class Proj2 = identity>
73596b674f2SHui Xie    requires mergeable<I1, I2, O, Comp, Proj1, Proj2>
73696b674f2SHui Xie    constexpr set_intersection_result<borrowed_iterator_t<R1>, borrowed_iterator_t<R2>, O>
73796b674f2SHui Xie      set_intersection(R1&& r1, R2&& r2, O result,
73896b674f2SHui Xie                       Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});                         // since C++20
73996b674f2SHui Xie
7407d426a39SNikolas Klauser  template <class _InIter, class _OutIter>
7417d426a39SNikolas Klauser  using reverse_copy_result = in_out_result<_InIter, _OutIter>;                                     // since C++20
7427d426a39SNikolas Klauser
7437d426a39SNikolas Klauser  template<bidirectional_iterator I, sentinel_for<I> S, weakly_incrementable O>
7447d426a39SNikolas Klauser    requires indirectly_copyable<I, O>
7457d426a39SNikolas Klauser    constexpr ranges::reverse_copy_result<I, O>
7467d426a39SNikolas Klauser      ranges::reverse_copy(I first, S last, O result);                                              // since C++20
7477d426a39SNikolas Klauser
7487d426a39SNikolas Klauser  template<bidirectional_range R, weakly_incrementable O>
7497d426a39SNikolas Klauser    requires indirectly_copyable<iterator_t<R>, O>
7507d426a39SNikolas Klauser    constexpr ranges::reverse_copy_result<borrowed_iterator_t<R>, O>
7517d426a39SNikolas Klauser      ranges::reverse_copy(R&& r, O result);                                                        // since C++20
7527d426a39SNikolas Klauser
75333e5f159SKonstantin Varlamov  template<permutable I, sentinel_for<I> S>
75433e5f159SKonstantin Varlamov    constexpr subrange<I> rotate(I first, I middle, S last);                                        // since C++20
75533e5f159SKonstantin Varlamov
75633e5f159SKonstantin Varlamov  template<forward_range R>
75733e5f159SKonstantin Varlamov    requires permutable<iterator_t<R>>
75833e5f159SKonstantin Varlamov    constexpr borrowed_subrange_t<R> rotate(R&& r, iterator_t<R> middle);                           // Since C++20
75933e5f159SKonstantin Varlamov
7607d426a39SNikolas Klauser  template <class _InIter, class _OutIter>
7617d426a39SNikolas Klauser  using rotate_copy_result = in_out_result<_InIter, _OutIter>;                                      // since C++20
7627d426a39SNikolas Klauser
7637d426a39SNikolas Klauser  template<forward_iterator I, sentinel_for<I> S, weakly_incrementable O>
7647d426a39SNikolas Klauser    requires indirectly_copyable<I, O>
7657d426a39SNikolas Klauser    constexpr ranges::rotate_copy_result<I, O>
7667d426a39SNikolas Klauser      ranges::rotate_copy(I first, I middle, S last, O result);                                     // since C++20
7677d426a39SNikolas Klauser
7687d426a39SNikolas Klauser  template<forward_range R, weakly_incrementable O>
7697d426a39SNikolas Klauser    requires indirectly_copyable<iterator_t<R>, O>
7707d426a39SNikolas Klauser    constexpr ranges::rotate_copy_result<borrowed_iterator_t<R>, O>
7717d426a39SNikolas Klauser      ranges::rotate_copy(R&& r, iterator_t<R> middle, O result);                                   // since C++20
7727d426a39SNikolas Klauser
773732cb123SKonstantin Varlamov  template<input_iterator I, sentinel_for<I> S, weakly_incrementable O, class Gen>
774732cb123SKonstantin Varlamov    requires (forward_iterator<I> || random_access_iterator<O>) &&
775732cb123SKonstantin Varlamov            indirectly_copyable<I, O> &&
776732cb123SKonstantin Varlamov            uniform_random_bit_generator<remove_reference_t<Gen>>
777732cb123SKonstantin Varlamov    O sample(I first, S last, O out, iter_difference_t<I> n, Gen&& g);                              // Since C++20
778732cb123SKonstantin Varlamov
779732cb123SKonstantin Varlamov  template<input_range R, weakly_incrementable O, class Gen>
780732cb123SKonstantin Varlamov    requires (forward_range<R> || random_access_iterator<O>) &&
781732cb123SKonstantin Varlamov            indirectly_copyable<iterator_t<R>, O> &&
782732cb123SKonstantin Varlamov            uniform_random_bit_generator<remove_reference_t<Gen>>
783732cb123SKonstantin Varlamov    O sample(R&& r, O out, range_difference_t<R> n, Gen&& g);                                       // Since C++20
784732cb123SKonstantin Varlamov
78514cf74d6SKonstantin Varlamov  template<random_access_iterator I, sentinel_for<I> S, class Gen>
78614cf74d6SKonstantin Varlamov    requires permutable<I> &&
78714cf74d6SKonstantin Varlamov            uniform_random_bit_generator<remove_reference_t<Gen>>
78814cf74d6SKonstantin Varlamov    I shuffle(I first, S last, Gen&& g);                                                           // Since C++20
78914cf74d6SKonstantin Varlamov
79014cf74d6SKonstantin Varlamov  template<random_access_range R, class Gen>
79114cf74d6SKonstantin Varlamov    requires permutable<iterator_t<R>> &&
79214cf74d6SKonstantin Varlamov            uniform_random_bit_generator<remove_reference_t<Gen>>
79314cf74d6SKonstantin Varlamov    borrowed_iterator_t<R> shuffle(R&& r, Gen&& g);                                                // Since C++20
79414cf74d6SKonstantin Varlamov
795101d1e9bSNikolas Klauser  template<forward_iterator I1, sentinel_for<I1> S1, forward_iterator I2,
796*80f03ecbSNikolas Klauser         sentinel_for<I2> S2, class Proj1 = identity, class Proj2 = identity,
797*80f03ecbSNikolas Klauser         indirect_equivalence_relation<projected<I1, Proj1>,
798*80f03ecbSNikolas Klauser                                       projected<I2, Proj2>> Pred = ranges::equal_to>
799*80f03ecbSNikolas Klauser  constexpr bool ranges::is_permutation(I1 first1, S1 last1, I2 first2, S2 last2,
800*80f03ecbSNikolas Klauser                                        Pred pred = {},
801*80f03ecbSNikolas Klauser                                        Proj1 proj1 = {}, Proj2 proj2 = {});                       // Since C++20
802*80f03ecbSNikolas Klauser
803*80f03ecbSNikolas Klauser  template<forward_range R1, forward_range R2,
804*80f03ecbSNikolas Klauser         class Proj1 = identity, class Proj2 = identity,
805*80f03ecbSNikolas Klauser         indirect_equivalence_relation<projected<iterator_t<R1>, Proj1>,
806*80f03ecbSNikolas Klauser                                       projected<iterator_t<R2>, Proj2>> Pred = ranges::equal_to>
807*80f03ecbSNikolas Klauser  constexpr bool ranges::is_permutation(R1&& r1, R2&& r2, Pred pred = {},
808*80f03ecbSNikolas Klauser                                        Proj1 proj1 = {}, Proj2 proj2 = {});                       // Since C++20
809*80f03ecbSNikolas Klauser
810*80f03ecbSNikolas Klauser  template<forward_iterator I1, sentinel_for<I1> S1, forward_iterator I2,
811101d1e9bSNikolas Klauser           sentinel_for<I2> S2, class Pred = ranges::equal_to,
812101d1e9bSNikolas Klauser           class Proj1 = identity, class Proj2 = identity>
813101d1e9bSNikolas Klauser    requires indirectly_comparable<I1, I2, Pred, Proj1, Proj2>
814101d1e9bSNikolas Klauser    constexpr subrange<I1>
815101d1e9bSNikolas Klauser      ranges::search(I1 first1, S1 last1, I2 first2, S2 last2, Pred pred = {},
816101d1e9bSNikolas Klauser                     Proj1 proj1 = {}, Proj2 proj2 = {});                                           // since C++20
817101d1e9bSNikolas Klauser
818101d1e9bSNikolas Klauser  template<forward_range R1, forward_range R2, class Pred = ranges::equal_to,
819101d1e9bSNikolas Klauser           class Proj1 = identity, class Proj2 = identity>
820101d1e9bSNikolas Klauser    requires indirectly_comparable<iterator_t<R1>, iterator_t<R2>, Pred, Proj1, Proj2>
821101d1e9bSNikolas Klauser    constexpr borrowed_subrange_t<R1>
822101d1e9bSNikolas Klauser      ranges::search(R1&& r1, R2&& r2, Pred pred = {},
823101d1e9bSNikolas Klauser                     Proj1 proj1 = {}, Proj2 proj2 = {});                                           // since C++20
824101d1e9bSNikolas Klauser
825101d1e9bSNikolas Klauser  template<forward_iterator I, sentinel_for<I> S, class T,
826101d1e9bSNikolas Klauser           class Pred = ranges::equal_to, class Proj = identity>
827101d1e9bSNikolas Klauser    requires indirectly_comparable<I, const T*, Pred, Proj>
828101d1e9bSNikolas Klauser    constexpr subrange<I>
829101d1e9bSNikolas Klauser      ranges::search_n(I first, S last, iter_difference_t<I> count,
830101d1e9bSNikolas Klauser                       const T& value, Pred pred = {}, Proj proj = {});                             // since C++20
831101d1e9bSNikolas Klauser
832101d1e9bSNikolas Klauser  template<forward_range R, class T, class Pred = ranges::equal_to,
833101d1e9bSNikolas Klauser           class Proj = identity>
834101d1e9bSNikolas Klauser    requires indirectly_comparable<iterator_t<R>, const T*, Pred, Proj>
835101d1e9bSNikolas Klauser    constexpr borrowed_subrange_t<R>
836101d1e9bSNikolas Klauser      ranges::search_n(R&& r, range_difference_t<R> count,
837101d1e9bSNikolas Klauser                       const T& value, Pred pred = {}, Proj proj = {});                             // since C++20
838101d1e9bSNikolas Klauser
839101d1e9bSNikolas Klauser  template<forward_iterator I1, sentinel_for<I1> S1, forward_iterator I2, sentinel_for<I2> S2,
840101d1e9bSNikolas Klauser           class Pred = ranges::equal_to, class Proj1 = identity, class Proj2 = identity>
841101d1e9bSNikolas Klauser    requires indirectly_comparable<I1, I2, Pred, Proj1, Proj2>
842101d1e9bSNikolas Klauser    constexpr subrange<I1>
843101d1e9bSNikolas Klauser      ranges::find_end(I1 first1, S1 last1, I2 first2, S2 last2, Pred pred = {},
844101d1e9bSNikolas Klauser                       Proj1 proj1 = {}, Proj2 proj2 = {});                                         // since C++20
845101d1e9bSNikolas Klauser
846101d1e9bSNikolas Klauser  template<forward_range R1, forward_range R2,
847101d1e9bSNikolas Klauser           class Pred = ranges::equal_to, class Proj1 = identity, class Proj2 = identity>
848101d1e9bSNikolas Klauser    requires indirectly_comparable<iterator_t<R1>, iterator_t<R2>, Pred, Proj1, Proj2>
849101d1e9bSNikolas Klauser    constexpr borrowed_subrange_t<R1>
850101d1e9bSNikolas Klauser      ranges::find_end(R1&& r1, R2&& r2, Pred pred = {},
851101d1e9bSNikolas Klauser                       Proj1 proj1 = {}, Proj2 proj2 = {});                                         // since C++20
852101d1e9bSNikolas Klauser
853a5c0638dSHui Xie  template<class I1, class I2, class O>
854a5c0638dSHui Xie    using set_symmetric_difference_result = in_in_out_result<I1, I2, O>;                            // since C++20
855a5c0638dSHui Xie
856a5c0638dSHui Xie  template<input_iterator I1, sentinel_for<I1> S1, input_iterator I2, sentinel_for<I2> S2,
857a5c0638dSHui Xie           weakly_incrementable O, class Comp = ranges::less,
858a5c0638dSHui Xie           class Proj1 = identity, class Proj2 = identity>
859a5c0638dSHui Xie    requires mergeable<I1, I2, O, Comp, Proj1, Proj2>
860a5c0638dSHui Xie    constexpr set_symmetric_difference_result<I1, I2, O>
861a5c0638dSHui Xie      set_symmetric_difference(I1 first1, S1 last1, I2 first2, S2 last2, O result,
862a5c0638dSHui Xie                               Comp comp = {}, Proj1 proj1 = {},
863a5c0638dSHui Xie                               Proj2 proj2 = {});                                                   // since C++20
864a5c0638dSHui Xie
865a5c0638dSHui Xie  template<input_range R1, input_range R2, weakly_incrementable O,
866a5c0638dSHui Xie           class Comp = ranges::less, class Proj1 = identity, class Proj2 = identity>
867a5c0638dSHui Xie    requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
868a5c0638dSHui Xie    constexpr set_symmetric_difference_result<borrowed_iterator_t<R1>,
869a5c0638dSHui Xie                                                      borrowed_iterator_t<R2>, O>
870a5c0638dSHui Xie      set_symmetric_difference(R1&& r1, R2&& r2, O result, Comp comp = {},
871a5c0638dSHui Xie                               Proj1 proj1 = {}, Proj2 proj2 = {});                                 // since C++20
872a5c0638dSHui Xie
8730f6364b8SHui Xie  template<forward_iterator I, sentinel_for<I> S, class T, class Proj = identity,
8740f6364b8SHui Xie           indirect_strict_weak_order<const T*, projected<I, Proj>> Comp = ranges::less>
8750f6364b8SHui Xie    constexpr subrange<I>
8760f6364b8SHui Xie      equal_range(I first, S last, const T& value, Comp comp = {}, Proj proj = {});                 // since C++20
8770f6364b8SHui Xie
8780f6364b8SHui Xie  template<forward_range R, class T, class Proj = identity,
8790f6364b8SHui Xie           indirect_strict_weak_order<const T*, projected<iterator_t<R>, Proj>> Comp =
8800f6364b8SHui Xie             ranges::less>
8810f6364b8SHui Xie    constexpr borrowed_subrange_t<R>
8820f6364b8SHui Xie      equal_range(R&& r, const T& value, Comp comp = {}, Proj proj = {});                           // since C++20
8830f6364b8SHui Xie
8843151b95dSHui Xie  template<class I1, class I2, class O>
8853151b95dSHui Xie    using set_union_result = in_in_out_result<I1, I2, O>;                                           // since C++20
8863151b95dSHui Xie
8873151b95dSHui Xie  template<input_iterator I1, sentinel_for<I1> S1, input_iterator I2, sentinel_for<I2> S2,
8883151b95dSHui Xie           weakly_incrementable O, class Comp = ranges::less,
8893151b95dSHui Xie           class Proj1 = identity, class Proj2 = identity>
8903151b95dSHui Xie    requires mergeable<I1, I2, O, Comp, Proj1, Proj2>
8913151b95dSHui Xie    constexpr set_union_result<I1, I2, O>
8923151b95dSHui Xie      set_union(I1 first1, S1 last1, I2 first2, S2 last2, O result, Comp comp = {},
8933151b95dSHui Xie                Proj1 proj1 = {}, Proj2 proj2 = {});                                                // since C++20
8943151b95dSHui Xie
8953151b95dSHui Xie  template<input_range R1, input_range R2, weakly_incrementable O,
8963151b95dSHui Xie           class Comp = ranges::less, class Proj1 = identity, class Proj2 = identity>
8973151b95dSHui Xie    requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
8983151b95dSHui Xie    constexpr set_union_result<borrowed_iterator_t<R1>, borrowed_iterator_t<R2>, O>
8993151b95dSHui Xie      set_union(R1&& r1, R2&& r2, O result, Comp comp = {},
9003151b95dSHui Xie                Proj1 proj1 = {}, Proj2 proj2 = {});                                                // since C++20
901c559964dSHui Xie
902c559964dSHui Xie  template<input_iterator I1, sentinel_for<I1> S1, input_iterator I2, sentinel_for<I2> S2,
903c559964dSHui Xie           class Proj1 = identity, class Proj2 = identity,
904c559964dSHui Xie           indirect_strict_weak_order<projected<I1, Proj1>, projected<I2, Proj2>> Comp =
905c559964dSHui Xie             ranges::less>
906c559964dSHui Xie    constexpr bool includes(I1 first1, S1 last1, I2 first2, S2 last2, Comp comp = {},
907c559964dSHui Xie                            Proj1 proj1 = {}, Proj2 proj2 = {});                                   // Since C++20
908c559964dSHui Xie
909c559964dSHui Xie  template<input_range R1, input_range R2, class Proj1 = identity,
910c559964dSHui Xie           class Proj2 = identity,
911c559964dSHui Xie           indirect_strict_weak_order<projected<iterator_t<R1>, Proj1>,
912c559964dSHui Xie                                      projected<iterator_t<R2>, Proj2>> Comp = ranges::less>
913c559964dSHui Xie    constexpr bool includes(R1&& r1, R2&& r2, Comp comp = {},
914c559964dSHui Xie                            Proj1 proj1 = {}, Proj2 proj2 = {});                                   // Since C++20
915e38b9de6SHui Xie
916e38b9de6SHui Xie  template<bidirectional_iterator I, sentinel_for<I> S, class Comp = ranges::less,
917e38b9de6SHui Xie           class Proj = identity>
918e38b9de6SHui Xie    requires sortable<I, Comp, Proj>
919e38b9de6SHui Xie    I inplace_merge(I first, I middle, S last, Comp comp = {}, Proj proj = {});                    // Since C++20
920e38b9de6SHui Xie
921e38b9de6SHui Xie  template<bidirectional_range R, class Comp = ranges::less, class Proj = identity>
922e38b9de6SHui Xie    requires sortable<iterator_t<R>, Comp, Proj>
923e38b9de6SHui Xie    borrowed_iterator_t<R>
924e38b9de6SHui Xie      inplace_merge(R&& r, iterator_t<R> middle, Comp comp = {},
925e38b9de6SHui Xie                    Proj proj = {});                                                               // Since C++20
92662f1e663SHui Xie
92762f1e663SHui Xie  template<permutable I, sentinel_for<I> S, class Proj = identity,
92862f1e663SHui Xie           indirect_equivalence_relation<projected<I, Proj>> C = ranges::equal_to>
92962f1e663SHui Xie    constexpr subrange<I> unique(I first, S last, C comp = {}, Proj proj = {});                    // Since C++20
93062f1e663SHui Xie
93162f1e663SHui Xie  template<forward_range R, class Proj = identity,
93262f1e663SHui Xie           indirect_equivalence_relation<projected<iterator_t<R>, Proj>> C = ranges::equal_to>
93362f1e663SHui Xie    requires permutable<iterator_t<R>>
93462f1e663SHui Xie    constexpr borrowed_subrange_t<R>
93562f1e663SHui Xie      unique(R&& r, C comp = {}, Proj proj = {});                                                  // Since C++20
93662f1e663SHui Xie
93762f1e663SHui Xie  template<input_iterator I, sentinel_for<I> S, weakly_incrementable O, class Proj = identity,
93862f1e663SHui Xie           indirect_equivalence_relation<projected<I, Proj>> C = ranges::equal_to>
93962f1e663SHui Xie    requires indirectly_copyable<I, O> &&
94062f1e663SHui Xie             (forward_iterator<I> ||
94162f1e663SHui Xie              (input_iterator<O> && same_as<iter_value_t<I>, iter_value_t<O>>) ||
94262f1e663SHui Xie              indirectly_copyable_storable<I, O>)
94362f1e663SHui Xie    constexpr unique_copy_result<I, O>
94462f1e663SHui Xie      unique_copy(I first, S last, O result, C comp = {}, Proj proj = {});                         // Since C++20
94562f1e663SHui Xie
94662f1e663SHui Xie  template<input_range R, weakly_incrementable O, class Proj = identity,
94762f1e663SHui Xie           indirect_equivalence_relation<projected<iterator_t<R>, Proj>> C = ranges::equal_to>
94862f1e663SHui Xie    requires indirectly_copyable<iterator_t<R>, O> &&
94962f1e663SHui Xie             (forward_iterator<iterator_t<R>> ||
95062f1e663SHui Xie              (input_iterator<O> && same_as<range_value_t<R>, iter_value_t<O>>) ||
95162f1e663SHui Xie              indirectly_copyable_storable<iterator_t<R>, O>)
95262f1e663SHui Xie    constexpr unique_copy_result<borrowed_iterator_t<R>, O>
95362f1e663SHui Xie      unique_copy(R&& r, O result, C comp = {}, Proj proj = {});                                   // Since C++20
95433a5980fSNikolas Klauser
95533a5980fSNikolas Klauser  template<class I, class O>
95633a5980fSNikolas Klauser      using remove_copy_result = in_out_result<I, O>;                                              // Since C++20
95733a5980fSNikolas Klauser
95833a5980fSNikolas Klauser  template<input_iterator I, sentinel_for<I> S, weakly_incrementable O, class T,
95933a5980fSNikolas Klauser           class Proj = identity>
96033a5980fSNikolas Klauser             indirect_binary_predicate<ranges::equal_to, projected<I, Proj>, const T*>
96133a5980fSNikolas Klauser    constexpr remove_copy_result<I, O>
96233a5980fSNikolas Klauser      remove_copy(I first, S last, O result, const T& value, Proj proj = {});                      // Since C++20
96333a5980fSNikolas Klauser
96433a5980fSNikolas Klauser  template<input_range R, weakly_incrementable O, class T, class Proj = identity>
96533a5980fSNikolas Klauser    requires indirectly_copyable<iterator_t<R>, O> &&
96633a5980fSNikolas Klauser             indirect_binary_predicate<ranges::equal_to,
96733a5980fSNikolas Klauser                                       projected<iterator_t<R>, Proj>, const T*>
96833a5980fSNikolas Klauser    constexpr remove_copy_result<borrowed_iterator_t<R>, O>
96933a5980fSNikolas Klauser      remove_copy(R&& r, O result, const T& value, Proj proj = {});                                // Since C++20
97033a5980fSNikolas Klauser
97133a5980fSNikolas Klauser  template<class I, class O>
97233a5980fSNikolas Klauser      using remove_copy_if_result = in_out_result<I, O>;                                           // Since C++20
97333a5980fSNikolas Klauser
97433a5980fSNikolas Klauser  template<input_iterator I, sentinel_for<I> S, weakly_incrementable O,
97533a5980fSNikolas Klauser           class Proj = identity, indirect_unary_predicate<projected<I, Proj>> Pred>
97633a5980fSNikolas Klauser    requires indirectly_copyable<I, O>
97733a5980fSNikolas Klauser    constexpr remove_copy_if_result<I, O>
97833a5980fSNikolas Klauser      remove_copy_if(I first, S last, O result, Pred pred, Proj proj = {});                        // Since C++20
97933a5980fSNikolas Klauser
98033a5980fSNikolas Klauser  template<input_range R, weakly_incrementable O, class Proj = identity,
98133a5980fSNikolas Klauser           indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
98233a5980fSNikolas Klauser    requires indirectly_copyable<iterator_t<R>, O>
98333a5980fSNikolas Klauser    constexpr remove_copy_if_result<borrowed_iterator_t<R>, O>
98433a5980fSNikolas Klauser      remove_copy_if(R&& r, O result, Pred pred, Proj proj = {});                                  // Since C++20
98533a5980fSNikolas Klauser
98640c79a4dSNikolas Klauser  template<class I, class O>
98740c79a4dSNikolas Klauser      using replace_copy_result = in_out_result<I, O>;                                             // Since C++20
98840c79a4dSNikolas Klauser
98940c79a4dSNikolas Klauser  template<input_iterator I, sentinel_for<I> S, class T1, class T2,
99040c79a4dSNikolas Klauser           output_iterator<const T2&> O, class Proj = identity>
99140c79a4dSNikolas Klauser    requires indirectly_copyable<I, O> &&
99240c79a4dSNikolas Klauser             indirect_binary_predicate<ranges::equal_to, projected<I, Proj>, const T1*>
99340c79a4dSNikolas Klauser    constexpr replace_copy_result<I, O>
99440c79a4dSNikolas Klauser      replace_copy(I first, S last, O result, const T1& old_value, const T2& new_value,
99540c79a4dSNikolas Klauser                   Proj proj = {});                                                                // Since C++20
99640c79a4dSNikolas Klauser
99740c79a4dSNikolas Klauser  template<input_range R, class T1, class T2, output_iterator<const T2&> O,
99840c79a4dSNikolas Klauser           class Proj = identity>
99940c79a4dSNikolas Klauser    requires indirectly_copyable<iterator_t<R>, O> &&
100040c79a4dSNikolas Klauser             indirect_binary_predicate<ranges::equal_to,
100140c79a4dSNikolas Klauser                                       projected<iterator_t<R>, Proj>, const T1*>
100240c79a4dSNikolas Klauser    constexpr replace_copy_result<borrowed_iterator_t<R>, O>
100340c79a4dSNikolas Klauser      replace_copy(R&& r, O result, const T1& old_value, const T2& new_value,
100440c79a4dSNikolas Klauser                   Proj proj = {});                                                                // Since C++20
100540c79a4dSNikolas Klauser
100640c79a4dSNikolas Klauser  template<class I, class O>
100740c79a4dSNikolas Klauser      using replace_copy_if_result = in_out_result<I, O>;                                          // Since C++20
100840c79a4dSNikolas Klauser
100940c79a4dSNikolas Klauser  template<input_iterator I, sentinel_for<I> S, class T, output_iterator<const T&> O,
101040c79a4dSNikolas Klauser           class Proj = identity, indirect_unary_predicate<projected<I, Proj>> Pred>
101140c79a4dSNikolas Klauser    requires indirectly_copyable<I, O>
101240c79a4dSNikolas Klauser    constexpr replace_copy_if_result<I, O>
101340c79a4dSNikolas Klauser      replace_copy_if(I first, S last, O result, Pred pred, const T& new_value,
101440c79a4dSNikolas Klauser                      Proj proj = {});                                                             // Since C++20
101540c79a4dSNikolas Klauser
101640c79a4dSNikolas Klauser  template<input_range R, class T, output_iterator<const T&> O, class Proj = identity,
101740c79a4dSNikolas Klauser           indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
101840c79a4dSNikolas Klauser    requires indirectly_copyable<iterator_t<R>, O>
101940c79a4dSNikolas Klauser    constexpr replace_copy_if_result<borrowed_iterator_t<R>, O>
102040c79a4dSNikolas Klauser      replace_copy_if(R&& r, O result, Pred pred, const T& new_value,
102140c79a4dSNikolas Klauser                      Proj proj = {});                                                             // Since C++20
102240c79a4dSNikolas Klauser
10231ee16f10SNikolas Klauser  template<class I>
10241ee16f10SNikolas Klauser    using prev_permutation_result = in_found_result<I>;                                            // Since C++20
10251ee16f10SNikolas Klauser
10261ee16f10SNikolas Klauser  template<bidirectional_iterator I, sentinel_for<I> S, class Comp = ranges::less,
10271ee16f10SNikolas Klauser           class Proj = identity>
10281ee16f10SNikolas Klauser    requires sortable<I, Comp, Proj>
10291ee16f10SNikolas Klauser    constexpr ranges::prev_permutation_result<I>
10301ee16f10SNikolas Klauser      ranges::prev_permutation(I first, S last, Comp comp = {}, Proj proj = {});                   // Since C++20
10311ee16f10SNikolas Klauser
10321ee16f10SNikolas Klauser  template<bidirectional_range R, class Comp = ranges::less,
10331ee16f10SNikolas Klauser           class Proj = identity>
10341ee16f10SNikolas Klauser    requires sortable<iterator_t<R>, Comp, Proj>
10351ee16f10SNikolas Klauser    constexpr ranges::prev_permutation_result<borrowed_iterator_t<R>>
10361ee16f10SNikolas Klauser      ranges::prev_permutation(R&& r, Comp comp = {}, Proj proj = {});                             // Since C++20
10371ee16f10SNikolas Klauser
10381ee16f10SNikolas Klauser  template<class I>
10391ee16f10SNikolas Klauser    using next_permutation_result = in_found_result<I>;                                            // Since C++20
10401ee16f10SNikolas Klauser
10411ee16f10SNikolas Klauser  template<bidirectional_iterator I, sentinel_for<I> S, class Comp = ranges::less,
10421ee16f10SNikolas Klauser           class Proj = identity>
10431ee16f10SNikolas Klauser    requires sortable<I, Comp, Proj>
10441ee16f10SNikolas Klauser    constexpr ranges::next_permutation_result<I>
10451ee16f10SNikolas Klauser      ranges::next_permutation(I first, S last, Comp comp = {}, Proj proj = {});                   // Since C++20
10461ee16f10SNikolas Klauser
10471ee16f10SNikolas Klauser  template<bidirectional_range R, class Comp = ranges::less,
10481ee16f10SNikolas Klauser           class Proj = identity>
10491ee16f10SNikolas Klauser    requires sortable<iterator_t<R>, Comp, Proj>
10501ee16f10SNikolas Klauser    constexpr ranges::next_permutation_result<borrowed_iterator_t<R>>
10511ee16f10SNikolas Klauser      ranges::next_permutation(R&& r, Comp comp = {}, Proj proj = {});                             // Since C++20
10521ee16f10SNikolas Klauser
1053d3729bb3SNikolas Klauser}
1054d3729bb3SNikolas Klauser
10551ee16f10SNikolas Klausertemplate <class InputIterator, class Predicate>
1056706ffef7SMarshall Clow    constexpr bool     // constexpr in C++20
10573e519524SHoward Hinnant    all_of(InputIterator first, InputIterator last, Predicate pred);
10583e519524SHoward Hinnant
10593e519524SHoward Hinnanttemplate <class InputIterator, class Predicate>
1060706ffef7SMarshall Clow    constexpr bool     // constexpr in C++20
10613e519524SHoward Hinnant    any_of(InputIterator first, InputIterator last, Predicate pred);
10623e519524SHoward Hinnant
10633e519524SHoward Hinnanttemplate <class InputIterator, class Predicate>
1064706ffef7SMarshall Clow    constexpr bool     // constexpr in C++20
10653e519524SHoward Hinnant    none_of(InputIterator first, InputIterator last, Predicate pred);
10663e519524SHoward Hinnant
10673e519524SHoward Hinnanttemplate <class InputIterator, class Function>
10681b9a4ffdSMarshall Clow    constexpr Function          // constexpr in C++20
10693e519524SHoward Hinnant    for_each(InputIterator first, InputIterator last, Function f);
10703e519524SHoward Hinnant
1071d5c65ffaSMarshall Clowtemplate<class InputIterator, class Size, class Function>
10721b9a4ffdSMarshall Clow    constexpr InputIterator     // constexpr in C++20
10731b9a4ffdSMarshall Clow    for_each_n(InputIterator first, Size n, Function f); // C++17
1074d5c65ffaSMarshall Clow
10753e519524SHoward Hinnanttemplate <class InputIterator, class T>
107649c7643cSMarshall Clow    constexpr InputIterator     // constexpr in C++20
10773e519524SHoward Hinnant    find(InputIterator first, InputIterator last, const T& value);
10783e519524SHoward Hinnant
10793e519524SHoward Hinnanttemplate <class InputIterator, class Predicate>
108049c7643cSMarshall Clow    constexpr InputIterator     // constexpr in C++20
10813e519524SHoward Hinnant    find_if(InputIterator first, InputIterator last, Predicate pred);
10823e519524SHoward Hinnant
10833e519524SHoward Hinnanttemplate<class InputIterator, class Predicate>
1084b8bc4e15SArthur O'Dwyer    constexpr InputIterator     // constexpr in C++20
10853e519524SHoward Hinnant    find_if_not(InputIterator first, InputIterator last, Predicate pred);
10863e519524SHoward Hinnant
10873e519524SHoward Hinnanttemplate <class ForwardIterator1, class ForwardIterator2>
1088b8bc4e15SArthur O'Dwyer    constexpr ForwardIterator1  // constexpr in C++20
10893e519524SHoward Hinnant    find_end(ForwardIterator1 first1, ForwardIterator1 last1,
10903e519524SHoward Hinnant             ForwardIterator2 first2, ForwardIterator2 last2);
10913e519524SHoward Hinnant
10923e519524SHoward Hinnanttemplate <class ForwardIterator1, class ForwardIterator2, class BinaryPredicate>
1093b8bc4e15SArthur O'Dwyer    constexpr ForwardIterator1  // constexpr in C++20
10943e519524SHoward Hinnant    find_end(ForwardIterator1 first1, ForwardIterator1 last1,
10953e519524SHoward Hinnant             ForwardIterator2 first2, ForwardIterator2 last2, BinaryPredicate pred);
10963e519524SHoward Hinnant
10973e519524SHoward Hinnanttemplate <class ForwardIterator1, class ForwardIterator2>
10988694428eSMarshall Clow    constexpr ForwardIterator1  // constexpr in C++20
10993e519524SHoward Hinnant    find_first_of(ForwardIterator1 first1, ForwardIterator1 last1,
11003e519524SHoward Hinnant                  ForwardIterator2 first2, ForwardIterator2 last2);
11013e519524SHoward Hinnant
11023e519524SHoward Hinnanttemplate <class ForwardIterator1, class ForwardIterator2, class BinaryPredicate>
11038694428eSMarshall Clow    constexpr ForwardIterator1  // constexpr in C++20
11043e519524SHoward Hinnant    find_first_of(ForwardIterator1 first1, ForwardIterator1 last1,
11053e519524SHoward Hinnant                  ForwardIterator2 first2, ForwardIterator2 last2, BinaryPredicate pred);
11063e519524SHoward Hinnant
11073e519524SHoward Hinnanttemplate <class ForwardIterator>
11088694428eSMarshall Clow    constexpr ForwardIterator   // constexpr in C++20
11093e519524SHoward Hinnant    adjacent_find(ForwardIterator first, ForwardIterator last);
11103e519524SHoward Hinnant
11113e519524SHoward Hinnanttemplate <class ForwardIterator, class BinaryPredicate>
11128694428eSMarshall Clow    constexpr ForwardIterator   // constexpr in C++20
11133e519524SHoward Hinnant    adjacent_find(ForwardIterator first, ForwardIterator last, BinaryPredicate pred);
11143e519524SHoward Hinnant
11153e519524SHoward Hinnanttemplate <class InputIterator, class T>
1116056f15e3SMarshall Clow    constexpr typename iterator_traits<InputIterator>::difference_type  // constexpr in C++20
11173e519524SHoward Hinnant    count(InputIterator first, InputIterator last, const T& value);
11183e519524SHoward Hinnant
11193e519524SHoward Hinnanttemplate <class InputIterator, class Predicate>
1120056f15e3SMarshall Clow    constexpr typename iterator_traits<InputIterator>::difference_type // constexpr in C++20
11213e519524SHoward Hinnant    count_if(InputIterator first, InputIterator last, Predicate pred);
11223e519524SHoward Hinnant
11233e519524SHoward Hinnanttemplate <class InputIterator1, class InputIterator2>
11246538e28dSMarshall Clow    constexpr pair<InputIterator1, InputIterator2>   // constexpr in C++20
11253e519524SHoward Hinnant    mismatch(InputIterator1 first1, InputIterator1 last1, InputIterator2 first2);
11263e519524SHoward Hinnant
11270b0bbd2fSMarshall Clowtemplate <class InputIterator1, class InputIterator2>
11286538e28dSMarshall Clow    constexpr pair<InputIterator1, InputIterator2>   // constexpr in C++20
11290b0bbd2fSMarshall Clow    mismatch(InputIterator1 first1, InputIterator1 last1,
11300b0bbd2fSMarshall Clow             InputIterator2 first2, InputIterator2 last2); // **C++14**
11310b0bbd2fSMarshall Clow
11323e519524SHoward Hinnanttemplate <class InputIterator1, class InputIterator2, class BinaryPredicate>
11336538e28dSMarshall Clow    constexpr pair<InputIterator1, InputIterator2>   // constexpr in C++20
11343e519524SHoward Hinnant    mismatch(InputIterator1 first1, InputIterator1 last1,
11353e519524SHoward Hinnant             InputIterator2 first2, BinaryPredicate pred);
11363e519524SHoward Hinnant
11370b0bbd2fSMarshall Clowtemplate <class InputIterator1, class InputIterator2, class BinaryPredicate>
11386538e28dSMarshall Clow    constexpr pair<InputIterator1, InputIterator2>   // constexpr in C++20
11390b0bbd2fSMarshall Clow    mismatch(InputIterator1 first1, InputIterator1 last1,
11400b0bbd2fSMarshall Clow             InputIterator2 first2, InputIterator2 last2,
11410b0bbd2fSMarshall Clow             BinaryPredicate pred); // **C++14**
11420b0bbd2fSMarshall Clow
11433e519524SHoward Hinnanttemplate <class InputIterator1, class InputIterator2>
11446538e28dSMarshall Clow    constexpr bool      // constexpr in C++20
11453e519524SHoward Hinnant    equal(InputIterator1 first1, InputIterator1 last1, InputIterator2 first2);
11463e519524SHoward Hinnant
11470b0bbd2fSMarshall Clowtemplate <class InputIterator1, class InputIterator2>
11486538e28dSMarshall Clow    constexpr bool      // constexpr in C++20
11490b0bbd2fSMarshall Clow    equal(InputIterator1 first1, InputIterator1 last1,
11500b0bbd2fSMarshall Clow          InputIterator2 first2, InputIterator2 last2); // **C++14**
11510b0bbd2fSMarshall Clow
11523e519524SHoward Hinnanttemplate <class InputIterator1, class InputIterator2, class BinaryPredicate>
11536538e28dSMarshall Clow    constexpr bool      // constexpr in C++20
11543e519524SHoward Hinnant    equal(InputIterator1 first1, InputIterator1 last1,
11553e519524SHoward Hinnant          InputIterator2 first2, BinaryPredicate pred);
11563e519524SHoward Hinnant
11570b0bbd2fSMarshall Clowtemplate <class InputIterator1, class InputIterator2, class BinaryPredicate>
11586538e28dSMarshall Clow    constexpr bool      // constexpr in C++20
11590b0bbd2fSMarshall Clow    equal(InputIterator1 first1, InputIterator1 last1,
11600b0bbd2fSMarshall Clow          InputIterator2 first2, InputIterator2 last2,
11610b0bbd2fSMarshall Clow          BinaryPredicate pred); // **C++14**
11620b0bbd2fSMarshall Clow
11633e519524SHoward Hinnanttemplate<class ForwardIterator1, class ForwardIterator2>
116449c7643cSMarshall Clow    constexpr bool      // constexpr in C++20
11653e519524SHoward Hinnant    is_permutation(ForwardIterator1 first1, ForwardIterator1 last1,
11663e519524SHoward Hinnant                   ForwardIterator2 first2);
11673e519524SHoward Hinnant
11680b0bbd2fSMarshall Clowtemplate<class ForwardIterator1, class ForwardIterator2>
116949c7643cSMarshall Clow    constexpr bool      // constexpr in C++20
11700b0bbd2fSMarshall Clow    is_permutation(ForwardIterator1 first1, ForwardIterator1 last1,
11710b0bbd2fSMarshall Clow                   ForwardIterator2 first2, ForwardIterator2 last2); // **C++14**
11720b0bbd2fSMarshall Clow
11733e519524SHoward Hinnanttemplate<class ForwardIterator1, class ForwardIterator2, class BinaryPredicate>
117449c7643cSMarshall Clow    constexpr bool      // constexpr in C++20
11753e519524SHoward Hinnant    is_permutation(ForwardIterator1 first1, ForwardIterator1 last1,
11763e519524SHoward Hinnant                   ForwardIterator2 first2, BinaryPredicate pred);
11773e519524SHoward Hinnant
11780b0bbd2fSMarshall Clowtemplate<class ForwardIterator1, class ForwardIterator2, class BinaryPredicate>
117949c7643cSMarshall Clow    constexpr bool      // constexpr in C++20
11800b0bbd2fSMarshall Clow    is_permutation(ForwardIterator1 first1, ForwardIterator1 last1,
11810b0bbd2fSMarshall Clow                   ForwardIterator2 first2, ForwardIterator2 last2,
11820b0bbd2fSMarshall Clow                   BinaryPredicate pred);  // **C++14**
11830b0bbd2fSMarshall Clow
11843e519524SHoward Hinnanttemplate <class ForwardIterator1, class ForwardIterator2>
118512f0a779SMarshall Clow    constexpr ForwardIterator1      // constexpr in C++20
11863e519524SHoward Hinnant    search(ForwardIterator1 first1, ForwardIterator1 last1,
11873e519524SHoward Hinnant           ForwardIterator2 first2, ForwardIterator2 last2);
11883e519524SHoward Hinnant
11893e519524SHoward Hinnanttemplate <class ForwardIterator1, class ForwardIterator2, class BinaryPredicate>
119012f0a779SMarshall Clow    constexpr ForwardIterator1      // constexpr in C++20
11913e519524SHoward Hinnant    search(ForwardIterator1 first1, ForwardIterator1 last1,
11923e519524SHoward Hinnant           ForwardIterator2 first2, ForwardIterator2 last2, BinaryPredicate pred);
11933e519524SHoward Hinnant
11943e519524SHoward Hinnanttemplate <class ForwardIterator, class Size, class T>
119512f0a779SMarshall Clow    constexpr ForwardIterator       // constexpr in C++20
11963e519524SHoward Hinnant    search_n(ForwardIterator first, ForwardIterator last, Size count, const T& value);
11973e519524SHoward Hinnant
11983e519524SHoward Hinnanttemplate <class ForwardIterator, class Size, class T, class BinaryPredicate>
119912f0a779SMarshall Clow    constexpr ForwardIterator       // constexpr in C++20
12003e519524SHoward Hinnant    search_n(ForwardIterator first, ForwardIterator last,
12013e519524SHoward Hinnant             Size count, const T& value, BinaryPredicate pred);
12023e519524SHoward Hinnant
12033e519524SHoward Hinnanttemplate <class InputIterator, class OutputIterator>
120413c90a57SLouis Dionne    constexpr OutputIterator      // constexpr in C++20
12053e519524SHoward Hinnant    copy(InputIterator first, InputIterator last, OutputIterator result);
12063e519524SHoward Hinnant
12073e519524SHoward Hinnanttemplate<class InputIterator, class OutputIterator, class Predicate>
120813c90a57SLouis Dionne    constexpr OutputIterator      // constexpr in C++20
12093e519524SHoward Hinnant    copy_if(InputIterator first, InputIterator last,
12103e519524SHoward Hinnant            OutputIterator result, Predicate pred);
12113e519524SHoward Hinnant
12123e519524SHoward Hinnanttemplate<class InputIterator, class Size, class OutputIterator>
121313c90a57SLouis Dionne    constexpr OutputIterator      // constexpr in C++20
12143e519524SHoward Hinnant    copy_n(InputIterator first, Size n, OutputIterator result);
12153e519524SHoward Hinnant
12163e519524SHoward Hinnanttemplate <class BidirectionalIterator1, class BidirectionalIterator2>
121713c90a57SLouis Dionne    constexpr BidirectionalIterator2      // constexpr in C++20
12183e519524SHoward Hinnant    copy_backward(BidirectionalIterator1 first, BidirectionalIterator1 last,
12193e519524SHoward Hinnant                  BidirectionalIterator2 result);
12203e519524SHoward Hinnant
122179a2b4baSKonstantin Varlamov// [alg.move], move
122279a2b4baSKonstantin Varlamovtemplate<class InputIterator, class OutputIterator>
122379a2b4baSKonstantin Varlamov    constexpr OutputIterator move(InputIterator first, InputIterator last,
122479a2b4baSKonstantin Varlamov                                OutputIterator result);
122579a2b4baSKonstantin Varlamov
122679a2b4baSKonstantin Varlamovtemplate<class BidirectionalIterator1, class BidirectionalIterator2>
122779a2b4baSKonstantin Varlamov    constexpr BidirectionalIterator2
122879a2b4baSKonstantin Varlamov    move_backward(BidirectionalIterator1 first, BidirectionalIterator1 last,
122979a2b4baSKonstantin Varlamov                  BidirectionalIterator2 result);
123079a2b4baSKonstantin Varlamov
12313e519524SHoward Hinnanttemplate <class ForwardIterator1, class ForwardIterator2>
1232b8bc4e15SArthur O'Dwyer    constexpr ForwardIterator2    // constexpr in C++20
12333e519524SHoward Hinnant    swap_ranges(ForwardIterator1 first1, ForwardIterator1 last1, ForwardIterator2 first2);
12343e519524SHoward Hinnant
123579a2b4baSKonstantin Varlamovnamespace ranges {
123679a2b4baSKonstantin Varlamov    template<class I1, class I2>
123779a2b4baSKonstantin Varlamov    using swap_ranges_result = in_in_result<I1, I2>;
123879a2b4baSKonstantin Varlamov
12399d905319SNikolas Klausertemplate<input_iterator I1, sentinel_for<I1> S1, input_iterator I2, sentinel_for<I2> S2>
12409d905319SNikolas Klauser        requires indirectly_swappable<I1, I2>
12419d905319SNikolas Klauser    constexpr ranges::swap_ranges_result<I1, I2>
124279a2b4baSKonstantin Varlamov        swap_ranges(I1 first1, S1 last1, I2 first2, S2 last2);
12439d905319SNikolas Klauser
12449d905319SNikolas Klausertemplate<input_range R1, input_range R2>
12459d905319SNikolas Klauser        requires indirectly_swappable<iterator_t<R1>, iterator_t<R2>>
12469d905319SNikolas Klauser    constexpr ranges::swap_ranges_result<borrowed_iterator_t<R1>, borrowed_iterator_t<R2>>
124779a2b4baSKonstantin Varlamov        swap_ranges(R1&& r1, R2&& r2);
124879a2b4baSKonstantin Varlamov}
12499d905319SNikolas Klauser
12503e519524SHoward Hinnanttemplate <class ForwardIterator1, class ForwardIterator2>
1251b8bc4e15SArthur O'Dwyer    constexpr void                // constexpr in C++20
12523e519524SHoward Hinnant    iter_swap(ForwardIterator1 a, ForwardIterator2 b);
12533e519524SHoward Hinnant
12543e519524SHoward Hinnanttemplate <class InputIterator, class OutputIterator, class UnaryOperation>
125599894b61SMarshall Clow    constexpr OutputIterator      // constexpr in C++20
12563e519524SHoward Hinnant    transform(InputIterator first, InputIterator last, OutputIterator result, UnaryOperation op);
12573e519524SHoward Hinnant
12583e519524SHoward Hinnanttemplate <class InputIterator1, class InputIterator2, class OutputIterator, class BinaryOperation>
125999894b61SMarshall Clow    constexpr OutputIterator      // constexpr in C++20
12603e519524SHoward Hinnant    transform(InputIterator1 first1, InputIterator1 last1, InputIterator2 first2,
12613e519524SHoward Hinnant              OutputIterator result, BinaryOperation binary_op);
12623e519524SHoward Hinnant
12633e519524SHoward Hinnanttemplate <class ForwardIterator, class T>
126412c7423fSMarshall Clow    constexpr void      // constexpr in C++20
12653e519524SHoward Hinnant    replace(ForwardIterator first, ForwardIterator last, const T& old_value, const T& new_value);
12663e519524SHoward Hinnant
12673e519524SHoward Hinnanttemplate <class ForwardIterator, class Predicate, class T>
126812c7423fSMarshall Clow    constexpr void      // constexpr in C++20
12693e519524SHoward Hinnant    replace_if(ForwardIterator first, ForwardIterator last, Predicate pred, const T& new_value);
12703e519524SHoward Hinnant
12713e519524SHoward Hinnanttemplate <class InputIterator, class OutputIterator, class T>
127212c7423fSMarshall Clow    constexpr OutputIterator      // constexpr in C++20
12733e519524SHoward Hinnant    replace_copy(InputIterator first, InputIterator last, OutputIterator result,
12743e519524SHoward Hinnant                 const T& old_value, const T& new_value);
12753e519524SHoward Hinnant
12763e519524SHoward Hinnanttemplate <class InputIterator, class OutputIterator, class Predicate, class T>
127712c7423fSMarshall Clow    constexpr OutputIterator      // constexpr in C++20
12783e519524SHoward Hinnant    replace_copy_if(InputIterator first, InputIterator last, OutputIterator result, Predicate pred, const T& new_value);
12793e519524SHoward Hinnant
12803e519524SHoward Hinnanttemplate <class ForwardIterator, class T>
12814bfb9313SMarshall Clow    constexpr void      // constexpr in C++20
12823e519524SHoward Hinnant    fill(ForwardIterator first, ForwardIterator last, const T& value);
12833e519524SHoward Hinnant
12843e519524SHoward Hinnanttemplate <class OutputIterator, class Size, class T>
12854bfb9313SMarshall Clow    constexpr OutputIterator      // constexpr in C++20
12863e519524SHoward Hinnant    fill_n(OutputIterator first, Size n, const T& value);
12873e519524SHoward Hinnant
12883e519524SHoward Hinnanttemplate <class ForwardIterator, class Generator>
12894bfb9313SMarshall Clow    constexpr void      // constexpr in C++20
12903e519524SHoward Hinnant    generate(ForwardIterator first, ForwardIterator last, Generator gen);
12913e519524SHoward Hinnant
12923e519524SHoward Hinnanttemplate <class OutputIterator, class Size, class Generator>
12934bfb9313SMarshall Clow    constexpr OutputIterator      // constexpr in C++20
12943e519524SHoward Hinnant    generate_n(OutputIterator first, Size n, Generator gen);
12953e519524SHoward Hinnant
12963e519524SHoward Hinnanttemplate <class ForwardIterator, class T>
1297e8ea8296SMarshall Clow    constexpr ForwardIterator     // constexpr in C++20
12983e519524SHoward Hinnant    remove(ForwardIterator first, ForwardIterator last, const T& value);
12993e519524SHoward Hinnant
13003e519524SHoward Hinnanttemplate <class ForwardIterator, class Predicate>
1301e8ea8296SMarshall Clow    constexpr ForwardIterator     // constexpr in C++20
13023e519524SHoward Hinnant    remove_if(ForwardIterator first, ForwardIterator last, Predicate pred);
13033e519524SHoward Hinnant
13043e519524SHoward Hinnanttemplate <class InputIterator, class OutputIterator, class T>
1305e8ea8296SMarshall Clow    constexpr OutputIterator     // constexpr in C++20
13063e519524SHoward Hinnant    remove_copy(InputIterator first, InputIterator last, OutputIterator result, const T& value);
13073e519524SHoward Hinnant
13083e519524SHoward Hinnanttemplate <class InputIterator, class OutputIterator, class Predicate>
1309e8ea8296SMarshall Clow    constexpr OutputIterator     // constexpr in C++20
13103e519524SHoward Hinnant    remove_copy_if(InputIterator first, InputIterator last, OutputIterator result, Predicate pred);
13113e519524SHoward Hinnant
13123e519524SHoward Hinnanttemplate <class ForwardIterator>
1313b8bc4e15SArthur O'Dwyer    constexpr ForwardIterator    // constexpr in C++20
13143e519524SHoward Hinnant    unique(ForwardIterator first, ForwardIterator last);
13153e519524SHoward Hinnant
13163e519524SHoward Hinnanttemplate <class ForwardIterator, class BinaryPredicate>
1317b8bc4e15SArthur O'Dwyer    constexpr ForwardIterator    // constexpr in C++20
13183e519524SHoward Hinnant    unique(ForwardIterator first, ForwardIterator last, BinaryPredicate pred);
13193e519524SHoward Hinnant
13203e519524SHoward Hinnanttemplate <class InputIterator, class OutputIterator>
1321b8bc4e15SArthur O'Dwyer    constexpr OutputIterator     // constexpr in C++20
13223e519524SHoward Hinnant    unique_copy(InputIterator first, InputIterator last, OutputIterator result);
13233e519524SHoward Hinnant
13243e519524SHoward Hinnanttemplate <class InputIterator, class OutputIterator, class BinaryPredicate>
1325b8bc4e15SArthur O'Dwyer    constexpr OutputIterator     // constexpr in C++20
13263e519524SHoward Hinnant    unique_copy(InputIterator first, InputIterator last, OutputIterator result, BinaryPredicate pred);
13273e519524SHoward Hinnant
13283e519524SHoward Hinnanttemplate <class BidirectionalIterator>
1329f851db3dSArthur O'Dwyer    constexpr void               // constexpr in C++20
13303e519524SHoward Hinnant    reverse(BidirectionalIterator first, BidirectionalIterator last);
13313e519524SHoward Hinnant
13323e519524SHoward Hinnanttemplate <class BidirectionalIterator, class OutputIterator>
1333e8ea8296SMarshall Clow    constexpr OutputIterator       // constexpr in C++20
13343e519524SHoward Hinnant    reverse_copy(BidirectionalIterator first, BidirectionalIterator last, OutputIterator result);
13353e519524SHoward Hinnant
13363e519524SHoward Hinnanttemplate <class ForwardIterator>
1337b8bc4e15SArthur O'Dwyer    constexpr ForwardIterator      // constexpr in C++20
13383e519524SHoward Hinnant    rotate(ForwardIterator first, ForwardIterator middle, ForwardIterator last);
13393e519524SHoward Hinnant
13403e519524SHoward Hinnanttemplate <class ForwardIterator, class OutputIterator>
1341b8bc4e15SArthur O'Dwyer    constexpr OutputIterator       // constexpr in C++20
13423e519524SHoward Hinnant    rotate_copy(ForwardIterator first, ForwardIterator middle, ForwardIterator last, OutputIterator result);
13433e519524SHoward Hinnant
13443e519524SHoward Hinnanttemplate <class RandomAccessIterator>
13453e519524SHoward Hinnant    void
13460f37a410SMarshall Clow    random_shuffle(RandomAccessIterator first, RandomAccessIterator last); // deprecated in C++14, removed in C++17
13473e519524SHoward Hinnant
13483e519524SHoward Hinnanttemplate <class RandomAccessIterator, class RandomNumberGenerator>
13493e519524SHoward Hinnant    void
135006965c1fSMarshall Clow    random_shuffle(RandomAccessIterator first, RandomAccessIterator last,
13510f37a410SMarshall Clow                   RandomNumberGenerator& rand);  // deprecated in C++14, removed in C++17
13523e519524SHoward Hinnant
1353e7154709SEric Fiseliertemplate<class PopulationIterator, class SampleIterator,
1354e7154709SEric Fiselier         class Distance, class UniformRandomBitGenerator>
1355e7154709SEric Fiselier    SampleIterator sample(PopulationIterator first, PopulationIterator last,
1356e7154709SEric Fiselier                          SampleIterator out, Distance n,
1357e7154709SEric Fiselier                          UniformRandomBitGenerator&& g); // C++17
1358e7154709SEric Fiselier
1359f9d540b0SHoward Hinnanttemplate<class RandomAccessIterator, class UniformRandomNumberGenerator>
1360f9d540b0SHoward Hinnant    void shuffle(RandomAccessIterator first, RandomAccessIterator last,
1361fb340102SHoward Hinnant                 UniformRandomNumberGenerator&& g);
1362f9d540b0SHoward Hinnant
13633fbd3eafSArthur O'Dwyertemplate<class ForwardIterator>
13643fbd3eafSArthur O'Dwyer  constexpr ForwardIterator
13653fbd3eafSArthur O'Dwyer    shift_left(ForwardIterator first, ForwardIterator last,
13663fbd3eafSArthur O'Dwyer               typename iterator_traits<ForwardIterator>::difference_type n); // C++20
13673fbd3eafSArthur O'Dwyer
13683fbd3eafSArthur O'Dwyertemplate<class ForwardIterator>
13693fbd3eafSArthur O'Dwyer  constexpr ForwardIterator
13703fbd3eafSArthur O'Dwyer    shift_right(ForwardIterator first, ForwardIterator last,
13713fbd3eafSArthur O'Dwyer                typename iterator_traits<ForwardIterator>::difference_type n); // C++20
13723fbd3eafSArthur O'Dwyer
13733e519524SHoward Hinnanttemplate <class InputIterator, class Predicate>
137449c7643cSMarshall Clow    constexpr bool  // constexpr in C++20
13753e519524SHoward Hinnant    is_partitioned(InputIterator first, InputIterator last, Predicate pred);
13763e519524SHoward Hinnant
13773e519524SHoward Hinnanttemplate <class ForwardIterator, class Predicate>
1378f851db3dSArthur O'Dwyer    constexpr ForwardIterator  // constexpr in C++20
13793e519524SHoward Hinnant    partition(ForwardIterator first, ForwardIterator last, Predicate pred);
13803e519524SHoward Hinnant
13813e519524SHoward Hinnanttemplate <class InputIterator, class OutputIterator1,
13823e519524SHoward Hinnant          class OutputIterator2, class Predicate>
13831b9a4ffdSMarshall Clow    constexpr pair<OutputIterator1, OutputIterator2>   // constexpr in C++20
13843e519524SHoward Hinnant    partition_copy(InputIterator first, InputIterator last,
13853e519524SHoward Hinnant                   OutputIterator1 out_true, OutputIterator2 out_false,
13863e519524SHoward Hinnant                   Predicate pred);
13873e519524SHoward Hinnant
13883e519524SHoward Hinnanttemplate <class ForwardIterator, class Predicate>
13893e519524SHoward Hinnant    ForwardIterator
13903e519524SHoward Hinnant    stable_partition(ForwardIterator first, ForwardIterator last, Predicate pred);
13913e519524SHoward Hinnant
13923e519524SHoward Hinnanttemplate<class ForwardIterator, class Predicate>
1393d57c03ddSMarshall Clow    constexpr ForwardIterator  // constexpr in C++20
13943e519524SHoward Hinnant    partition_point(ForwardIterator first, ForwardIterator last, Predicate pred);
13953e519524SHoward Hinnant
13963e519524SHoward Hinnanttemplate <class ForwardIterator>
139749c7643cSMarshall Clow    constexpr bool  // constexpr in C++20
13983e519524SHoward Hinnant    is_sorted(ForwardIterator first, ForwardIterator last);
13993e519524SHoward Hinnant
14003e519524SHoward Hinnanttemplate <class ForwardIterator, class Compare>
1401b8bc4e15SArthur O'Dwyer    constexpr bool  // constexpr in C++20
14023e519524SHoward Hinnant    is_sorted(ForwardIterator first, ForwardIterator last, Compare comp);
14033e519524SHoward Hinnant
14043e519524SHoward Hinnanttemplate<class ForwardIterator>
1405056f15e3SMarshall Clow    constexpr ForwardIterator    // constexpr in C++20
14063e519524SHoward Hinnant    is_sorted_until(ForwardIterator first, ForwardIterator last);
14073e519524SHoward Hinnant
14083e519524SHoward Hinnanttemplate <class ForwardIterator, class Compare>
1409056f15e3SMarshall Clow    constexpr ForwardIterator    // constexpr in C++20
14103e519524SHoward Hinnant    is_sorted_until(ForwardIterator first, ForwardIterator last, Compare comp);
14113e519524SHoward Hinnant
14123e519524SHoward Hinnanttemplate <class RandomAccessIterator>
1413493f1407SArthur O'Dwyer    constexpr void               // constexpr in C++20
14143e519524SHoward Hinnant    sort(RandomAccessIterator first, RandomAccessIterator last);
14153e519524SHoward Hinnant
14163e519524SHoward Hinnanttemplate <class RandomAccessIterator, class Compare>
1417493f1407SArthur O'Dwyer    constexpr void               // constexpr in C++20
14183e519524SHoward Hinnant    sort(RandomAccessIterator first, RandomAccessIterator last, Compare comp);
14193e519524SHoward Hinnant
14203e519524SHoward Hinnanttemplate <class RandomAccessIterator>
14213e519524SHoward Hinnant    void
14223e519524SHoward Hinnant    stable_sort(RandomAccessIterator first, RandomAccessIterator last);
14233e519524SHoward Hinnant
14243e519524SHoward Hinnanttemplate <class RandomAccessIterator, class Compare>
14253e519524SHoward Hinnant    void
14263e519524SHoward Hinnant    stable_sort(RandomAccessIterator first, RandomAccessIterator last, Compare comp);
14273e519524SHoward Hinnant
14283e519524SHoward Hinnanttemplate <class RandomAccessIterator>
14295386aa26SArthur O'Dwyer    constexpr void                    // constexpr in C++20
14303e519524SHoward Hinnant    partial_sort(RandomAccessIterator first, RandomAccessIterator middle, RandomAccessIterator last);
14313e519524SHoward Hinnant
14323e519524SHoward Hinnanttemplate <class RandomAccessIterator, class Compare>
14335386aa26SArthur O'Dwyer    constexpr void                    // constexpr in C++20
14343e519524SHoward Hinnant    partial_sort(RandomAccessIterator first, RandomAccessIterator middle, RandomAccessIterator last, Compare comp);
14353e519524SHoward Hinnant
14363e519524SHoward Hinnanttemplate <class InputIterator, class RandomAccessIterator>
14375386aa26SArthur O'Dwyer    constexpr RandomAccessIterator    // constexpr in C++20
14383e519524SHoward Hinnant    partial_sort_copy(InputIterator first, InputIterator last,
14393e519524SHoward Hinnant                      RandomAccessIterator result_first, RandomAccessIterator result_last);
14403e519524SHoward Hinnant
14413e519524SHoward Hinnanttemplate <class InputIterator, class RandomAccessIterator, class Compare>
14425386aa26SArthur O'Dwyer    constexpr RandomAccessIterator    // constexpr in C++20
14433e519524SHoward Hinnant    partial_sort_copy(InputIterator first, InputIterator last,
14443e519524SHoward Hinnant                      RandomAccessIterator result_first, RandomAccessIterator result_last, Compare comp);
14453e519524SHoward Hinnant
14463e519524SHoward Hinnanttemplate <class RandomAccessIterator>
14475d956563SArthur O'Dwyer    constexpr void                    // constexpr in C++20
14483e519524SHoward Hinnant    nth_element(RandomAccessIterator first, RandomAccessIterator nth, RandomAccessIterator last);
14493e519524SHoward Hinnant
14503e519524SHoward Hinnanttemplate <class RandomAccessIterator, class Compare>
14515d956563SArthur O'Dwyer    constexpr void                    // constexpr in C++20
14523e519524SHoward Hinnant    nth_element(RandomAccessIterator first, RandomAccessIterator nth, RandomAccessIterator last, Compare comp);
14533e519524SHoward Hinnant
14543e519524SHoward Hinnanttemplate <class ForwardIterator, class T>
1455d57c03ddSMarshall Clow    constexpr ForwardIterator                         // constexpr in C++20
14563e519524SHoward Hinnant    lower_bound(ForwardIterator first, ForwardIterator last, const T& value);
14573e519524SHoward Hinnant
14583e519524SHoward Hinnanttemplate <class ForwardIterator, class T, class Compare>
1459d57c03ddSMarshall Clow    constexpr ForwardIterator                         // constexpr in C++20
14603e519524SHoward Hinnant    lower_bound(ForwardIterator first, ForwardIterator last, const T& value, Compare comp);
14613e519524SHoward Hinnant
14623e519524SHoward Hinnanttemplate <class ForwardIterator, class T>
1463d57c03ddSMarshall Clow    constexpr ForwardIterator                         // constexpr in C++20
14643e519524SHoward Hinnant    upper_bound(ForwardIterator first, ForwardIterator last, const T& value);
14653e519524SHoward Hinnant
14663e519524SHoward Hinnanttemplate <class ForwardIterator, class T, class Compare>
1467d57c03ddSMarshall Clow    constexpr ForwardIterator                         // constexpr in C++20
14683e519524SHoward Hinnant    upper_bound(ForwardIterator first, ForwardIterator last, const T& value, Compare comp);
14693e519524SHoward Hinnant
14703e519524SHoward Hinnanttemplate <class ForwardIterator, class T>
1471d57c03ddSMarshall Clow    constexpr pair<ForwardIterator, ForwardIterator>  // constexpr in C++20
14723e519524SHoward Hinnant    equal_range(ForwardIterator first, ForwardIterator last, const T& value);
14733e519524SHoward Hinnant
14743e519524SHoward Hinnanttemplate <class ForwardIterator, class T, class Compare>
1475d57c03ddSMarshall Clow    constexpr pair<ForwardIterator, ForwardIterator>  // constexpr in C++20
14763e519524SHoward Hinnant    equal_range(ForwardIterator first, ForwardIterator last, const T& value, Compare comp);
14773e519524SHoward Hinnant
14783e519524SHoward Hinnanttemplate <class ForwardIterator, class T>
1479d57c03ddSMarshall Clow    constexpr bool                                    // constexpr in C++20
14803e519524SHoward Hinnant    binary_search(ForwardIterator first, ForwardIterator last, const T& value);
14813e519524SHoward Hinnant
14823e519524SHoward Hinnanttemplate <class ForwardIterator, class T, class Compare>
14838da1a487SMarshall Clow    constexpr bool                                    // constexpr in C++20
14843e519524SHoward Hinnant    binary_search(ForwardIterator first, ForwardIterator last, const T& value, Compare comp);
14853e519524SHoward Hinnant
14863e519524SHoward Hinnanttemplate <class InputIterator1, class InputIterator2, class OutputIterator>
148714098cf6SArthur O'Dwyer    constexpr OutputIterator                          // constexpr in C++20
14883e519524SHoward Hinnant    merge(InputIterator1 first1, InputIterator1 last1,
14893e519524SHoward Hinnant          InputIterator2 first2, InputIterator2 last2, OutputIterator result);
14903e519524SHoward Hinnant
14913e519524SHoward Hinnanttemplate <class InputIterator1, class InputIterator2, class OutputIterator, class Compare>
149214098cf6SArthur O'Dwyer    constexpr OutputIterator                          // constexpr in C++20
14933e519524SHoward Hinnant    merge(InputIterator1 first1, InputIterator1 last1,
14943e519524SHoward Hinnant          InputIterator2 first2, InputIterator2 last2, OutputIterator result, Compare comp);
14953e519524SHoward Hinnant
14963e519524SHoward Hinnanttemplate <class BidirectionalIterator>
14973e519524SHoward Hinnant    void
14983e519524SHoward Hinnant    inplace_merge(BidirectionalIterator first, BidirectionalIterator middle, BidirectionalIterator last);
14993e519524SHoward Hinnant
15003e519524SHoward Hinnanttemplate <class BidirectionalIterator, class Compare>
15013e519524SHoward Hinnant    void
15023e519524SHoward Hinnant    inplace_merge(BidirectionalIterator first, BidirectionalIterator middle, BidirectionalIterator last, Compare comp);
15033e519524SHoward Hinnant
15043e519524SHoward Hinnanttemplate <class InputIterator1, class InputIterator2>
15058da1a487SMarshall Clow    constexpr bool                                    // constexpr in C++20
15063e519524SHoward Hinnant    includes(InputIterator1 first1, InputIterator1 last1, InputIterator2 first2, InputIterator2 last2);
15073e519524SHoward Hinnant
15083e519524SHoward Hinnanttemplate <class InputIterator1, class InputIterator2, class Compare>
15098da1a487SMarshall Clow    constexpr bool                                    // constexpr in C++20
15103e519524SHoward Hinnant    includes(InputIterator1 first1, InputIterator1 last1, InputIterator2 first2, InputIterator2 last2, Compare comp);
15113e519524SHoward Hinnant
15123e519524SHoward Hinnanttemplate <class InputIterator1, class InputIterator2, class OutputIterator>
151314098cf6SArthur O'Dwyer    constexpr OutputIterator                          // constexpr in C++20
15143e519524SHoward Hinnant    set_union(InputIterator1 first1, InputIterator1 last1,
15153e519524SHoward Hinnant              InputIterator2 first2, InputIterator2 last2, OutputIterator result);
15163e519524SHoward Hinnant
15173e519524SHoward Hinnanttemplate <class InputIterator1, class InputIterator2, class OutputIterator, class Compare>
151814098cf6SArthur O'Dwyer    constexpr OutputIterator                          // constexpr in C++20
15193e519524SHoward Hinnant    set_union(InputIterator1 first1, InputIterator1 last1,
15203e519524SHoward Hinnant              InputIterator2 first2, InputIterator2 last2, OutputIterator result, Compare comp);
15213e519524SHoward Hinnant
15223e519524SHoward Hinnanttemplate <class InputIterator1, class InputIterator2, class OutputIterator>
15238da1a487SMarshall Clow    constexpr OutputIterator                         // constexpr in C++20
15243e519524SHoward Hinnant    set_intersection(InputIterator1 first1, InputIterator1 last1,
15253e519524SHoward Hinnant                     InputIterator2 first2, InputIterator2 last2, OutputIterator result);
15263e519524SHoward Hinnant
15273e519524SHoward Hinnanttemplate <class InputIterator1, class InputIterator2, class OutputIterator, class Compare>
15288da1a487SMarshall Clow    constexpr OutputIterator                         // constexpr in C++20
15293e519524SHoward Hinnant    set_intersection(InputIterator1 first1, InputIterator1 last1,
15303e519524SHoward Hinnant                     InputIterator2 first2, InputIterator2 last2, OutputIterator result, Compare comp);
15313e519524SHoward Hinnant
15323e519524SHoward Hinnanttemplate <class InputIterator1, class InputIterator2, class OutputIterator>
153314098cf6SArthur O'Dwyer    constexpr OutputIterator                         // constexpr in C++20
15343e519524SHoward Hinnant    set_difference(InputIterator1 first1, InputIterator1 last1,
15353e519524SHoward Hinnant                   InputIterator2 first2, InputIterator2 last2, OutputIterator result);
15363e519524SHoward Hinnant
15373e519524SHoward Hinnanttemplate <class InputIterator1, class InputIterator2, class OutputIterator, class Compare>
153814098cf6SArthur O'Dwyer    constexpr OutputIterator                         // constexpr in C++20
15393e519524SHoward Hinnant    set_difference(InputIterator1 first1, InputIterator1 last1,
15403e519524SHoward Hinnant                   InputIterator2 first2, InputIterator2 last2, OutputIterator result, Compare comp);
15413e519524SHoward Hinnant
15423e519524SHoward Hinnanttemplate <class InputIterator1, class InputIterator2, class OutputIterator>
154314098cf6SArthur O'Dwyer    constexpr OutputIterator                         // constexpr in C++20
15443e519524SHoward Hinnant    set_symmetric_difference(InputIterator1 first1, InputIterator1 last1,
15453e519524SHoward Hinnant                             InputIterator2 first2, InputIterator2 last2, OutputIterator result);
15463e519524SHoward Hinnant
15473e519524SHoward Hinnanttemplate <class InputIterator1, class InputIterator2, class OutputIterator, class Compare>
154814098cf6SArthur O'Dwyer    constexpr OutputIterator                         // constexpr in C++20
15493e519524SHoward Hinnant    set_symmetric_difference(InputIterator1 first1, InputIterator1 last1,
15503e519524SHoward Hinnant                             InputIterator2 first2, InputIterator2 last2, OutputIterator result, Compare comp);
15513e519524SHoward Hinnant
15523e519524SHoward Hinnanttemplate <class RandomAccessIterator>
15535386aa26SArthur O'Dwyer    constexpr void                                   // constexpr in C++20
15543e519524SHoward Hinnant    push_heap(RandomAccessIterator first, RandomAccessIterator last);
15553e519524SHoward Hinnant
15563e519524SHoward Hinnanttemplate <class RandomAccessIterator, class Compare>
15575386aa26SArthur O'Dwyer    constexpr void                                   // constexpr in C++20
15583e519524SHoward Hinnant    push_heap(RandomAccessIterator first, RandomAccessIterator last, Compare comp);
15593e519524SHoward Hinnant
15603e519524SHoward Hinnanttemplate <class RandomAccessIterator>
15615386aa26SArthur O'Dwyer    constexpr void                                   // constexpr in C++20
15623e519524SHoward Hinnant    pop_heap(RandomAccessIterator first, RandomAccessIterator last);
15633e519524SHoward Hinnant
15643e519524SHoward Hinnanttemplate <class RandomAccessIterator, class Compare>
15655386aa26SArthur O'Dwyer    constexpr void                                   // constexpr in C++20
15663e519524SHoward Hinnant    pop_heap(RandomAccessIterator first, RandomAccessIterator last, Compare comp);
15673e519524SHoward Hinnant
15683e519524SHoward Hinnanttemplate <class RandomAccessIterator>
15695386aa26SArthur O'Dwyer    constexpr void                                   // constexpr in C++20
15703e519524SHoward Hinnant    make_heap(RandomAccessIterator first, RandomAccessIterator last);
15713e519524SHoward Hinnant
15723e519524SHoward Hinnanttemplate <class RandomAccessIterator, class Compare>
15735386aa26SArthur O'Dwyer    constexpr void                                   // constexpr in C++20
15743e519524SHoward Hinnant    make_heap(RandomAccessIterator first, RandomAccessIterator last, Compare comp);
15753e519524SHoward Hinnant
15763e519524SHoward Hinnanttemplate <class RandomAccessIterator>
15775386aa26SArthur O'Dwyer    constexpr void                                   // constexpr in C++20
15783e519524SHoward Hinnant    sort_heap(RandomAccessIterator first, RandomAccessIterator last);
15793e519524SHoward Hinnant
15803e519524SHoward Hinnanttemplate <class RandomAccessIterator, class Compare>
15815386aa26SArthur O'Dwyer    constexpr void                                   // constexpr in C++20
15823e519524SHoward Hinnant    sort_heap(RandomAccessIterator first, RandomAccessIterator last, Compare comp);
15833e519524SHoward Hinnant
15843e519524SHoward Hinnanttemplate <class RandomAccessIterator>
158549c7643cSMarshall Clow    constexpr bool   // constexpr in C++20
15863e519524SHoward Hinnant    is_heap(RandomAccessIterator first, RandomAccessiterator last);
15873e519524SHoward Hinnant
15883e519524SHoward Hinnanttemplate <class RandomAccessIterator, class Compare>
158949c7643cSMarshall Clow    constexpr bool   // constexpr in C++20
15903e519524SHoward Hinnant    is_heap(RandomAccessIterator first, RandomAccessiterator last, Compare comp);
15913e519524SHoward Hinnant
15923e519524SHoward Hinnanttemplate <class RandomAccessIterator>
159349c7643cSMarshall Clow    constexpr RandomAccessIterator   // constexpr in C++20
15943e519524SHoward Hinnant    is_heap_until(RandomAccessIterator first, RandomAccessiterator last);
15953e519524SHoward Hinnant
15963e519524SHoward Hinnanttemplate <class RandomAccessIterator, class Compare>
159749c7643cSMarshall Clow    constexpr RandomAccessIterator   // constexpr in C++20
15983e519524SHoward Hinnant    is_heap_until(RandomAccessIterator first, RandomAccessiterator last, Compare comp);
15993e519524SHoward Hinnant
16004eb27b79SHoward Hinnanttemplate <class ForwardIterator>
1601b8bc4e15SArthur O'Dwyer    constexpr ForwardIterator        // constexpr in C++14
1602b8bc4e15SArthur O'Dwyer    min_element(ForwardIterator first, ForwardIterator last);
16034eb27b79SHoward Hinnant
16044eb27b79SHoward Hinnanttemplate <class ForwardIterator, class Compare>
1605b8bc4e15SArthur O'Dwyer    constexpr ForwardIterator        // constexpr in C++14
1606b8bc4e15SArthur O'Dwyer    min_element(ForwardIterator first, ForwardIterator last, Compare comp);
16074eb27b79SHoward Hinnant
16083e519524SHoward Hinnanttemplate <class T>
1609b8bc4e15SArthur O'Dwyer    constexpr const T&               // constexpr in C++14
1610b8bc4e15SArthur O'Dwyer    min(const T& a, const T& b);
16113e519524SHoward Hinnant
16123e519524SHoward Hinnanttemplate <class T, class Compare>
1613b8bc4e15SArthur O'Dwyer    constexpr const T&               // constexpr in C++14
1614b8bc4e15SArthur O'Dwyer    min(const T& a, const T& b, Compare comp);
16153e519524SHoward Hinnant
16163e519524SHoward Hinnanttemplate<class T>
1617b8bc4e15SArthur O'Dwyer    constexpr T                      // constexpr in C++14
1618b8bc4e15SArthur O'Dwyer    min(initializer_list<T> t);
16193e519524SHoward Hinnant
16203e519524SHoward Hinnanttemplate<class T, class Compare>
1621b8bc4e15SArthur O'Dwyer    constexpr T                      // constexpr in C++14
1622b8bc4e15SArthur O'Dwyer    min(initializer_list<T> t, Compare comp);
16233e519524SHoward Hinnant
1624146c14acSMarshall Clowtemplate<class T>
1625146c14acSMarshall Clow    constexpr const T& clamp(const T& v, const T& lo, const T& hi);               // C++17
1626146c14acSMarshall Clow
1627146c14acSMarshall Clowtemplate<class T, class Compare>
1628146c14acSMarshall Clow    constexpr const T& clamp(const T& v, const T& lo, const T& hi, Compare comp); // C++17
1629146c14acSMarshall Clow
16303e519524SHoward Hinnanttemplate <class ForwardIterator>
1631b8bc4e15SArthur O'Dwyer    constexpr ForwardIterator        // constexpr in C++14
1632b8bc4e15SArthur O'Dwyer    max_element(ForwardIterator first, ForwardIterator last);
16333e519524SHoward Hinnant
16343e519524SHoward Hinnanttemplate <class ForwardIterator, class Compare>
1635b8bc4e15SArthur O'Dwyer    constexpr ForwardIterator        // constexpr in C++14
1636b8bc4e15SArthur O'Dwyer    max_element(ForwardIterator first, ForwardIterator last, Compare comp);
16373e519524SHoward Hinnant
16384eb27b79SHoward Hinnanttemplate <class T>
1639b8bc4e15SArthur O'Dwyer    constexpr const T&               // constexpr in C++14
1640b8bc4e15SArthur O'Dwyer    max(const T& a, const T& b);
16414eb27b79SHoward Hinnant
16424eb27b79SHoward Hinnanttemplate <class T, class Compare>
1643b8bc4e15SArthur O'Dwyer    constexpr const T&               // constexpr in C++14
1644b8bc4e15SArthur O'Dwyer    max(const T& a, const T& b, Compare comp);
16454eb27b79SHoward Hinnant
16464eb27b79SHoward Hinnanttemplate<class T>
1647b8bc4e15SArthur O'Dwyer    constexpr T                      // constexpr in C++14
1648b8bc4e15SArthur O'Dwyer    max(initializer_list<T> t);
16494eb27b79SHoward Hinnant
16504eb27b79SHoward Hinnanttemplate<class T, class Compare>
1651b8bc4e15SArthur O'Dwyer    constexpr T                      // constexpr in C++14
1652b8bc4e15SArthur O'Dwyer    max(initializer_list<T> t, Compare comp);
16534eb27b79SHoward Hinnant
16544eb27b79SHoward Hinnanttemplate<class ForwardIterator>
1655b8bc4e15SArthur O'Dwyer    constexpr pair<ForwardIterator, ForwardIterator>  // constexpr in C++14
1656b8bc4e15SArthur O'Dwyer    minmax_element(ForwardIterator first, ForwardIterator last);
16574eb27b79SHoward Hinnant
16584eb27b79SHoward Hinnanttemplate<class ForwardIterator, class Compare>
1659b8bc4e15SArthur O'Dwyer    constexpr pair<ForwardIterator, ForwardIterator>  // constexpr in C++14
1660b8bc4e15SArthur O'Dwyer    minmax_element(ForwardIterator first, ForwardIterator last, Compare comp);
16614eb27b79SHoward Hinnant
16624eb27b79SHoward Hinnanttemplate<class T>
1663b8bc4e15SArthur O'Dwyer    constexpr pair<const T&, const T&>  // constexpr in C++14
1664b8bc4e15SArthur O'Dwyer    minmax(const T& a, const T& b);
16654eb27b79SHoward Hinnant
16664eb27b79SHoward Hinnanttemplate<class T, class Compare>
1667b8bc4e15SArthur O'Dwyer    constexpr pair<const T&, const T&>  // constexpr in C++14
1668b8bc4e15SArthur O'Dwyer    minmax(const T& a, const T& b, Compare comp);
16694eb27b79SHoward Hinnant
16704eb27b79SHoward Hinnanttemplate<class T>
1671b8bc4e15SArthur O'Dwyer    constexpr pair<T, T>                // constexpr in C++14
1672b8bc4e15SArthur O'Dwyer    minmax(initializer_list<T> t);
16734eb27b79SHoward Hinnant
16744eb27b79SHoward Hinnanttemplate<class T, class Compare>
1675b8bc4e15SArthur O'Dwyer    constexpr pair<T, T>                // constexpr in C++14
1676b8bc4e15SArthur O'Dwyer    minmax(initializer_list<T> t, Compare comp);
16774eb27b79SHoward Hinnant
16783e519524SHoward Hinnanttemplate <class InputIterator1, class InputIterator2>
16791b9a4ffdSMarshall Clow    constexpr bool     // constexpr in C++20
16803e519524SHoward Hinnant    lexicographical_compare(InputIterator1 first1, InputIterator1 last1, InputIterator2 first2, InputIterator2 last2);
16813e519524SHoward Hinnant
16823e519524SHoward Hinnanttemplate <class InputIterator1, class InputIterator2, class Compare>
16831b9a4ffdSMarshall Clow    constexpr bool     // constexpr in C++20
16843e519524SHoward Hinnant    lexicographical_compare(InputIterator1 first1, InputIterator1 last1,
16853e519524SHoward Hinnant                            InputIterator2 first2, InputIterator2 last2, Compare comp);
16863e519524SHoward Hinnant
16873e519524SHoward Hinnanttemplate <class BidirectionalIterator>
1688f851db3dSArthur O'Dwyer    constexpr bool     // constexpr in C++20
16893e519524SHoward Hinnant    next_permutation(BidirectionalIterator first, BidirectionalIterator last);
16903e519524SHoward Hinnant
16913e519524SHoward Hinnanttemplate <class BidirectionalIterator, class Compare>
1692f851db3dSArthur O'Dwyer    constexpr bool     // constexpr in C++20
16933e519524SHoward Hinnant    next_permutation(BidirectionalIterator first, BidirectionalIterator last, Compare comp);
16943e519524SHoward Hinnant
16953e519524SHoward Hinnanttemplate <class BidirectionalIterator>
1696f851db3dSArthur O'Dwyer    constexpr bool     // constexpr in C++20
16973e519524SHoward Hinnant    prev_permutation(BidirectionalIterator first, BidirectionalIterator last);
16983e519524SHoward Hinnant
16993e519524SHoward Hinnanttemplate <class BidirectionalIterator, class Compare>
1700f851db3dSArthur O'Dwyer    constexpr bool     // constexpr in C++20
17013e519524SHoward Hinnant    prev_permutation(BidirectionalIterator first, BidirectionalIterator last, Compare comp);
17023e519524SHoward Hinnant}  // std
17033e519524SHoward Hinnant
17043e519524SHoward Hinnant*/
17053e519524SHoward Hinnant
1706385cc25aSLouis Dionne#include <__assert> // all public C++ headers provide the assertion handler
1707ea2206d7SArthur O'Dwyer#include <__bits>
17083e519524SHoward Hinnant#include <__config>
1709134723edSLouis Dionne#include <__debug>
1710a1d07d57SHoward Hinnant#include <cstddef>
1711bfbd73f8SArthur O'Dwyer#include <cstring>
1712bfbd73f8SArthur O'Dwyer#include <memory>
1713bfbd73f8SArthur O'Dwyer#include <type_traits>
1714f56972e2SMarshall Clow#include <version>
17155d1a701dSHoward Hinnant
1716134723edSLouis Dionne#include <__algorithm/adjacent_find.h>
1717134723edSLouis Dionne#include <__algorithm/all_of.h>
1718134723edSLouis Dionne#include <__algorithm/any_of.h>
1719134723edSLouis Dionne#include <__algorithm/binary_search.h>
1720134723edSLouis Dionne#include <__algorithm/clamp.h>
1721134723edSLouis Dionne#include <__algorithm/comp.h>
1722134723edSLouis Dionne#include <__algorithm/comp_ref_type.h>
1723134723edSLouis Dionne#include <__algorithm/copy.h>
1724134723edSLouis Dionne#include <__algorithm/copy_backward.h>
1725134723edSLouis Dionne#include <__algorithm/copy_if.h>
1726134723edSLouis Dionne#include <__algorithm/copy_n.h>
1727134723edSLouis Dionne#include <__algorithm/count.h>
1728134723edSLouis Dionne#include <__algorithm/count_if.h>
1729134723edSLouis Dionne#include <__algorithm/equal.h>
1730134723edSLouis Dionne#include <__algorithm/equal_range.h>
1731134723edSLouis Dionne#include <__algorithm/fill.h>
17324d81a46fSArthur O'Dwyer#include <__algorithm/fill_n.h>
1733134723edSLouis Dionne#include <__algorithm/find.h>
1734134723edSLouis Dionne#include <__algorithm/find_end.h>
1735134723edSLouis Dionne#include <__algorithm/find_first_of.h>
1736134723edSLouis Dionne#include <__algorithm/find_if.h>
1737134723edSLouis Dionne#include <__algorithm/find_if_not.h>
1738134723edSLouis Dionne#include <__algorithm/for_each.h>
1739134723edSLouis Dionne#include <__algorithm/for_each_n.h>
1740134723edSLouis Dionne#include <__algorithm/generate.h>
17414d81a46fSArthur O'Dwyer#include <__algorithm/generate_n.h>
1742134723edSLouis Dionne#include <__algorithm/half_positive.h>
174368f4131cSNikolas Klauser#include <__algorithm/in_found_result.h>
17441e77b396SNikolas Klauser#include <__algorithm/in_fun_result.h>
1745f3514af4SNikolas Klauser#include <__algorithm/in_in_out_result.h>
1746d3729bb3SNikolas Klauser#include <__algorithm/in_in_result.h>
1747610979b3SNikolas Klauser#include <__algorithm/in_out_out_result.h>
17488d23b742SKonstantin Varlamov#include <__algorithm/in_out_result.h>
1749134723edSLouis Dionne#include <__algorithm/includes.h>
1750134723edSLouis Dionne#include <__algorithm/inplace_merge.h>
1751134723edSLouis Dionne#include <__algorithm/is_heap.h>
1752134723edSLouis Dionne#include <__algorithm/is_heap_until.h>
1753134723edSLouis Dionne#include <__algorithm/is_partitioned.h>
1754134723edSLouis Dionne#include <__algorithm/is_permutation.h>
1755134723edSLouis Dionne#include <__algorithm/is_sorted.h>
1756134723edSLouis Dionne#include <__algorithm/is_sorted_until.h>
17576adbc83eSChristopher Di Bella#include <__algorithm/iter_swap.h>
1758134723edSLouis Dionne#include <__algorithm/lexicographical_compare.h>
1759134723edSLouis Dionne#include <__algorithm/lower_bound.h>
1760134723edSLouis Dionne#include <__algorithm/make_heap.h>
1761134723edSLouis Dionne#include <__algorithm/max.h>
1762134723edSLouis Dionne#include <__algorithm/max_element.h>
1763134723edSLouis Dionne#include <__algorithm/merge.h>
1764134723edSLouis Dionne#include <__algorithm/min.h>
1765134723edSLouis Dionne#include <__algorithm/min_element.h>
1766807766beSNikolas Klauser#include <__algorithm/min_max_result.h>
1767134723edSLouis Dionne#include <__algorithm/minmax.h>
1768134723edSLouis Dionne#include <__algorithm/minmax_element.h>
1769134723edSLouis Dionne#include <__algorithm/mismatch.h>
1770134723edSLouis Dionne#include <__algorithm/move.h>
1771134723edSLouis Dionne#include <__algorithm/move_backward.h>
1772134723edSLouis Dionne#include <__algorithm/next_permutation.h>
1773134723edSLouis Dionne#include <__algorithm/none_of.h>
1774134723edSLouis Dionne#include <__algorithm/nth_element.h>
1775134723edSLouis Dionne#include <__algorithm/partial_sort.h>
1776134723edSLouis Dionne#include <__algorithm/partial_sort_copy.h>
1777134723edSLouis Dionne#include <__algorithm/partition.h>
1778134723edSLouis Dionne#include <__algorithm/partition_copy.h>
1779134723edSLouis Dionne#include <__algorithm/partition_point.h>
1780134723edSLouis Dionne#include <__algorithm/pop_heap.h>
1781134723edSLouis Dionne#include <__algorithm/prev_permutation.h>
1782134723edSLouis Dionne#include <__algorithm/push_heap.h>
1783916e9052SNikolas Klauser#include <__algorithm/ranges_adjacent_find.h>
17840e3dc1a5SNikolas Klauser#include <__algorithm/ranges_all_of.h>
17850e3dc1a5SNikolas Klauser#include <__algorithm/ranges_any_of.h>
178681715861SNikolas Klauser#include <__algorithm/ranges_binary_search.h>
1787f20566daSNikolas Klauser#include <__algorithm/ranges_clamp.h>
17881d83750fSNikolas Klauser#include <__algorithm/ranges_copy.h>
17891d83750fSNikolas Klauser#include <__algorithm/ranges_copy_backward.h>
17901d83750fSNikolas Klauser#include <__algorithm/ranges_copy_if.h>
17911d83750fSNikolas Klauser#include <__algorithm/ranges_copy_n.h>
17921306b102SNikolas Klauser#include <__algorithm/ranges_count.h>
17931306b102SNikolas Klauser#include <__algorithm/ranges_count_if.h>
1794569d6630SNikolas Klauser#include <__algorithm/ranges_equal.h>
17950f6364b8SHui Xie#include <__algorithm/ranges_equal_range.h>
17967af89a37SNikolas Klauser#include <__algorithm/ranges_fill.h>
17977af89a37SNikolas Klauser#include <__algorithm/ranges_fill_n.h>
1798ee0f8c40SNikolas Klauser#include <__algorithm/ranges_find.h>
1799101d1e9bSNikolas Klauser#include <__algorithm/ranges_find_end.h>
1800b79b2b67SNikolas Klauser#include <__algorithm/ranges_find_first_of.h>
1801ee0f8c40SNikolas Klauser#include <__algorithm/ranges_find_if.h>
1802ee0f8c40SNikolas Klauser#include <__algorithm/ranges_find_if_not.h>
180380045e9aSNikolas Klauser#include <__algorithm/ranges_for_each.h>
180480045e9aSNikolas Klauser#include <__algorithm/ranges_for_each_n.h>
1805ead7302bSKonstantin Varlamov#include <__algorithm/ranges_generate.h>
1806ead7302bSKonstantin Varlamov#include <__algorithm/ranges_generate_n.h>
1807c559964dSHui Xie#include <__algorithm/ranges_includes.h>
1808e38b9de6SHui Xie#include <__algorithm/ranges_inplace_merge.h>
1809d406c649SKonstantin Varlamov#include <__algorithm/ranges_is_heap.h>
1810d406c649SKonstantin Varlamov#include <__algorithm/ranges_is_heap_until.h>
181137ba1b9dSNikolas Klauser#include <__algorithm/ranges_is_partitioned.h>
1812*80f03ecbSNikolas Klauser#include <__algorithm/ranges_is_permutation.h>
181311e3ad29SNikolas Klauser#include <__algorithm/ranges_is_sorted.h>
181411e3ad29SNikolas Klauser#include <__algorithm/ranges_is_sorted_until.h>
1815afd5a4f2SNikolas Klauser#include <__algorithm/ranges_lexicographical_compare.h>
181681715861SNikolas Klauser#include <__algorithm/ranges_lower_bound.h>
1817c945bd0dSKonstantin Varlamov#include <__algorithm/ranges_make_heap.h>
1818e476df56SNikolas Klauser#include <__algorithm/ranges_max.h>
1819205557c9SNikolas Klauser#include <__algorithm/ranges_max_element.h>
182025607d14SHui Xie#include <__algorithm/ranges_merge.h>
1821f83d833eSNikolas Klauser#include <__algorithm/ranges_min.h>
18223b470d1cSNikolas Klauser#include <__algorithm/ranges_min_element.h>
182358d9ab70SNikolas Klauser#include <__algorithm/ranges_minmax.h>
182458d9ab70SNikolas Klauser#include <__algorithm/ranges_minmax_element.h>
1825c2cd15a6SNikolas Klauser#include <__algorithm/ranges_mismatch.h>
18262c3bbac0SNikolas Klauser#include <__algorithm/ranges_move.h>
18272c3bbac0SNikolas Klauser#include <__algorithm/ranges_move_backward.h>
18281ee16f10SNikolas Klauser#include <__algorithm/ranges_next_permutation.h>
18290e3dc1a5SNikolas Klauser#include <__algorithm/ranges_none_of.h>
183023c7328bSKonstantin Varlamov#include <__algorithm/ranges_nth_element.h>
18315dd19adaSvarconst#include <__algorithm/ranges_partial_sort.h>
18322c766efcSKonstantin Varlamov#include <__algorithm/ranges_partial_sort_copy.h>
18338ed702b8SKonstantin Varlamov#include <__algorithm/ranges_partition.h>
1834065202f3SKonstantin Varlamov#include <__algorithm/ranges_partition_copy.h>
1835065202f3SKonstantin Varlamov#include <__algorithm/ranges_partition_point.h>
1836c945bd0dSKonstantin Varlamov#include <__algorithm/ranges_pop_heap.h>
18371ee16f10SNikolas Klauser#include <__algorithm/ranges_prev_permutation.h>
1838c945bd0dSKonstantin Varlamov#include <__algorithm/ranges_push_heap.h>
1839f8cbe3cdSNikolas Klauser#include <__algorithm/ranges_remove.h>
184033a5980fSNikolas Klauser#include <__algorithm/ranges_remove_copy.h>
184133a5980fSNikolas Klauser#include <__algorithm/ranges_remove_copy_if.h>
1842f8cbe3cdSNikolas Klauser#include <__algorithm/ranges_remove_if.h>
1843ff6d5deeSNikolas Klauser#include <__algorithm/ranges_replace.h>
184440c79a4dSNikolas Klauser#include <__algorithm/ranges_replace_copy.h>
184540c79a4dSNikolas Klauser#include <__algorithm/ranges_replace_copy_if.h>
1846ff6d5deeSNikolas Klauser#include <__algorithm/ranges_replace_if.h>
18471d1a191eSNikolas Klauser#include <__algorithm/ranges_reverse.h>
18487d426a39SNikolas Klauser#include <__algorithm/ranges_reverse_copy.h>
184933e5f159SKonstantin Varlamov#include <__algorithm/ranges_rotate.h>
18507d426a39SNikolas Klauser#include <__algorithm/ranges_rotate_copy.h>
1851732cb123SKonstantin Varlamov#include <__algorithm/ranges_sample.h>
1852101d1e9bSNikolas Klauser#include <__algorithm/ranges_search.h>
1853101d1e9bSNikolas Klauser#include <__algorithm/ranges_search_n.h>
18541cdec6c9SHui Xie#include <__algorithm/ranges_set_difference.h>
185596b674f2SHui Xie#include <__algorithm/ranges_set_intersection.h>
1856a5c0638dSHui Xie#include <__algorithm/ranges_set_symmetric_difference.h>
18573151b95dSHui Xie#include <__algorithm/ranges_set_union.h>
185814cf74d6SKonstantin Varlamov#include <__algorithm/ranges_shuffle.h>
1859ff3989e6SKonstantin Varlamov#include <__algorithm/ranges_sort.h>
1860c945bd0dSKonstantin Varlamov#include <__algorithm/ranges_sort_heap.h>
18618ed702b8SKonstantin Varlamov#include <__algorithm/ranges_stable_partition.h>
186294c7b89fSKonstantin Varlamov#include <__algorithm/ranges_stable_sort.h>
18639d905319SNikolas Klauser#include <__algorithm/ranges_swap_ranges.h>
18643ba8548cSNikolas Klauser#include <__algorithm/ranges_transform.h>
186562f1e663SHui Xie#include <__algorithm/ranges_unique.h>
186662f1e663SHui Xie#include <__algorithm/ranges_unique_copy.h>
186781715861SNikolas Klauser#include <__algorithm/ranges_upper_bound.h>
1868134723edSLouis Dionne#include <__algorithm/remove.h>
1869134723edSLouis Dionne#include <__algorithm/remove_copy.h>
1870134723edSLouis Dionne#include <__algorithm/remove_copy_if.h>
1871134723edSLouis Dionne#include <__algorithm/remove_if.h>
1872134723edSLouis Dionne#include <__algorithm/replace.h>
1873134723edSLouis Dionne#include <__algorithm/replace_copy.h>
1874134723edSLouis Dionne#include <__algorithm/replace_copy_if.h>
1875134723edSLouis Dionne#include <__algorithm/replace_if.h>
1876134723edSLouis Dionne#include <__algorithm/reverse.h>
1877134723edSLouis Dionne#include <__algorithm/reverse_copy.h>
1878134723edSLouis Dionne#include <__algorithm/rotate.h>
1879134723edSLouis Dionne#include <__algorithm/rotate_copy.h>
1880134723edSLouis Dionne#include <__algorithm/sample.h>
1881134723edSLouis Dionne#include <__algorithm/search.h>
1882134723edSLouis Dionne#include <__algorithm/search_n.h>
1883134723edSLouis Dionne#include <__algorithm/set_difference.h>
1884134723edSLouis Dionne#include <__algorithm/set_intersection.h>
1885134723edSLouis Dionne#include <__algorithm/set_symmetric_difference.h>
1886134723edSLouis Dionne#include <__algorithm/set_union.h>
1887134723edSLouis Dionne#include <__algorithm/shift_left.h>
1888134723edSLouis Dionne#include <__algorithm/shift_right.h>
1889134723edSLouis Dionne#include <__algorithm/shuffle.h>
1890134723edSLouis Dionne#include <__algorithm/sift_down.h>
1891134723edSLouis Dionne#include <__algorithm/sort.h>
1892134723edSLouis Dionne#include <__algorithm/sort_heap.h>
1893134723edSLouis Dionne#include <__algorithm/stable_partition.h>
1894134723edSLouis Dionne#include <__algorithm/stable_sort.h>
18956adbc83eSChristopher Di Bella#include <__algorithm/swap_ranges.h>
1896134723edSLouis Dionne#include <__algorithm/transform.h>
1897134723edSLouis Dionne#include <__algorithm/unique.h>
18984d81a46fSArthur O'Dwyer#include <__algorithm/unique_copy.h>
1899134723edSLouis Dionne#include <__algorithm/unwrap_iter.h>
1900134723edSLouis Dionne#include <__algorithm/upper_bound.h>
1901c1bd9197SEric Fiselier
1902de4a57cbSLouis Dionne#ifndef _LIBCPP_REMOVE_TRANSITIVE_INCLUDES
1903de4a57cbSLouis Dionne#  include <chrono>
1904de4a57cbSLouis Dionne#  include <iterator>
1905de4a57cbSLouis Dionne#  include <utility>
1906de4a57cbSLouis Dionne#endif
1907de4a57cbSLouis Dionne
1908db1978b6SNikolas Klauser// standard-mandated includes
1909db1978b6SNikolas Klauser#include <initializer_list>
1910db1978b6SNikolas Klauser
1911073458b1SHoward Hinnant#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
19123e519524SHoward Hinnant#  pragma GCC system_header
1913073458b1SHoward Hinnant#endif
19143e519524SHoward Hinnant
19150a06eb91SLouis Dionne#if defined(_LIBCPP_HAS_PARALLEL_ALGORITHMS) && _LIBCPP_STD_VER >= 17
191695689243SLouis Dionne#   include <__pstl_algorithm>
19170a06eb91SLouis Dionne#endif
19180a06eb91SLouis Dionne
19193e519524SHoward Hinnant#endif // _LIBCPP_ALGORITHM
1920