std::minmax
Актуально для C++23.
#include <algorithm>
Актуально на 2024-03-18.
Define overload #1
template<class T> constexpr pair<const T&, const T&> minmax(const T& a, const T& b);
Вычисляет наименьшее и наибольшее между a и b.
Аргументы a и b сравниваются с помощью оператора "<".
Вернёт пару ссылок; first ссылается на минимальное, а second на максимальное значение.
Example, possible implementation
Define overload #2
template<class T, class Compare> constexpr pair<const T&, const T&> minmax(const T& a, const T& b, Compare comp);
Вычисляет наименьшее и наибольшее между a и b.
Аргументы a и b сравниваются с помощью бинарного предиката "comp".
Вернёт пару ссылок; first ссылается на минимальное, а second на максимальное значение.
Example, possible implementation
Define overload #3
template<class T> constexpr pair<T, T> minmax(initializer_list<T> t);
Ищет наименьшее и наибольшее значение в списске t.
Значения сравниваются с помощью оператора "<".
Вернёт пару содержащую минимальное и максимальное значения.
Example, possible implementation
Define overload #4
template<class T, class Compare> constexpr pair<T, T> minmax(initializer_list<T> t, Compare comp);
Ищет наименьшее и наибольшее значение в списске t.
Значения сравниваются с помощью бинарного предиката "comp".
Вернёт пару содержащую минимальное и максимальное значения.
Example, possible implementation
Examples
Example 1:
#include <iostream> #include <algorithm> int main() { auto data = {2, 2, 3, 4, 5, 6, 7, 7, 4, 4}; auto res = std::minmax(data); std::cout << res.first << '\n' << res.second << std::endl; return 0; }
2 7
Changelog
C++26
TODOC++23
TODOC++20
TODOC++17
TODOC++14
TODOC++11
TODOSee also
TODO
This page was last modified on 2024-03-18