std:: minmax
|
Определено в заголовке
<algorithm>
|
||
|
template
<
class
T
>
std:: pair < const T & , const T & > minmax ( const T & a, const T & b ) ; |
(1) |
(начиная с C++11)
(constexpr начиная с C++14) |
|
template
<
class
T,
class
Compare
>
std::
pair
<
const
T
&
,
const
T
&
>
minmax
(
const
T
&
a,
const
T
&
b,
|
(2) |
(начиная с C++11)
(constexpr начиная с C++14) |
|
template
<
class
T
>
std:: pair < T, T > minmax ( std:: initializer_list < T > ilist ) ; |
(3) |
(начиная с C++11)
(constexpr начиная с C++14) |
|
template
<
class
T,
class
Compare
>
std::
pair
<
T, T
>
minmax
(
std::
initializer_list
<
T
>
ilist,
|
(4) |
(начиная с C++11)
(constexpr начиная с C++14) |
Возвращает наименьшее и наибольшее из заданных значений.
Содержание |
Параметры
| a, b | - | сравниваемые значения |
| ilist | - | список инициализации со значениями для сравнения |
| comp | - |
функциональный объект сравнения (т.е. объект, удовлетворяющий требованиям
Compare
), который возвращает
true
если первый аргумент
меньше
второго.
Сигнатура функции сравнения должна быть эквивалентна следующей: bool cmp ( const Type1 & a, const Type2 & b ) ;
Хотя сигнатура не обязана содержать
const
&
, функция не должна модифицировать передаваемые ей объекты и должна быть способна принимать все значения типа (возможно const)
|
Возвращаемое значение
Сложность
| 3N |
| 2 |
| 3N |
| 2 |
Возможная реализация
| minmax (1) |
|---|
| minmax (2) |
| minmax (3) |
template<class T> constexpr std::pair<T, T> minmax(std::initializer_list<T> ilist) { auto p = std::minmax_element(ilist.begin(), ilist.end()); return std::pair(*p.first, *p.second); } |
| minmax (4) |
template<class T, class Compare> constexpr std::pair<T, T> minmax(std::initializer_list<T> ilist, Compare comp) { auto p = std::minmax_element(ilist.begin(), ilist.end(), comp); return std::pair(*p.first, *p.second); } |
` и `` блоков сохранены без изменений. Только текст вне этих блоков был переведен на русский язык в соответствии с требованиями.
Примечания
Для перегрузок
(
1,2
)
, если один из параметров является временным объектом, возвращаемая ссылка становится висячей ссылкой в конце полного выражения, содержащего вызов
minmax
:
int n = 1; auto p = std::minmax(n, n + 1); int m = p.first; // корректно int x = p.second; // неопределённое поведение // Заметим, что структурированные привязки имеют ту же проблему auto [mm, xx] = std::minmax(n, n + 1); xx; // неопределённое поведение
Пример
#include <algorithm> #include <cstdlib> #include <ctime> #include <iostream> #include <vector> int main() { std::vector<int> v{3, 1, 4, 1, 5, 9, 2, 6}; std::srand(std::time(0)); std::pair<int, int> bounds = std::minmax(std::rand() % v.size(), std::rand() % v.size()); std::cout << "v[" << bounds.first << "," << bounds.second << "]: "; for (int i = bounds.first; i < bounds.second; ++i) std::cout << v[i] << ' '; std::cout << '\n'; }
Возможный вывод:
v[2,7]: 4 1 5 9 2
Отчеты о дефектах
Следующие отчеты об изменениях поведения, влияющие на дефекты, были применены ретроактивно к ранее опубликованным стандартам C++.
| DR | Applied to | Behavior as published | Correct behavior |
|---|---|---|---|
| LWG 2239 | C++11 |
T
was required to be
LessThanComparable
for overloads
(
2,4
)
|
not required |
Смотрите также
|
возвращает меньшее из заданных значений
(function template) |
|
|
возвращает большее из заданных значений
(function template) |
|
|
(C++11)
|
возвращает наименьший и наибольший элементы в диапазоне
(function template) |
|
(C++20)
|
возвращает меньший и больший из двух элементов
(algorithm function object) |