@specsoftdev live:.cid.8e17e9b93cabb607 specsoftdev@gmail.com
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
TODO
C++23
TODO
C++20
TODO
C++17
TODO
C++14
TODO
C++11
TODO


See also

TODO

This page was last modified on 2024-03-18