std::minmax_element
Актуально для C++23.
#include <algorithm>
Актуально на 2024-03-17.
Define overload #1
template<class ForwardIterator> constexpr pair<ForwardIterator, ForwardIterator> minmax_element(ForwardIterator first_in, ForwardIterator last_in);
Ищет наименьший и наибольший элемент в диапазоне [first_in, last_in].
Элементы сравниваются с помощью оператора "<".
Вернёт пару итераторов, first будет указывать на первый минимальный элемент, last - на последний наибольший;
или {first, last} будут указывать на last_in, если диапазон пуст.
Example, possible implementation
Define overload #2
template<class ExecutionPolicy, class ForwardIterator> pair<ForwardIterator, ForwardIterator> minmax_element(ExecutionPolicy&& exec, ForwardIterator first, ForwardIterator last);
TODO
Example, possible implementation
Define overload #3
template<class ForwardIterator, class Compare> constexpr pair<ForwardIterator, ForwardIterator> minmax_element(ForwardIterator first, ForwardIterator last, Compare comp);
Ищет наименьший и наибольший элемент в диапазоне [first_in, last_in].
Элементы сравниваются с помощью бинарного предиката comp.
Вернёт пару итераторов, first будет указывать на первый минимальный элемент, last - на последний наибольший;
или {first, last} будут указывать на last_in, если диапазон пуст.
Example, possible implementation
Define overload #4
template<class ExecutionPolicy, class ForwardIterator, class Compare> pair<ForwardIterator, ForwardIterator> minmax_element(ExecutionPolicy&& exec, ForwardIterator first, ForwardIterator last, Compare comp);
TODO
Example, possible implementation
Examples
Example 1:
#include <iostream> #include <algorithm> int main() { auto data = {2, 2, 3, 4, 5, 6, 7, 7, 8, 9}; auto res = std::minmax_element(std::begin(data), std::end(data)); std::cout << *res.first << '\n' << *res.second << std::endl; return 0; }
2 9
Changelog
C++26
TODOC++23
TODOC++20
TODOC++17
TODOC++14
TODOC++11
TODOSee also
TODO
This page was last modified on 2024-03-17