Пространства имён
Варианты
Действия

std::min_element

Материал из cppreference.com
< cpp‎ | algorithm
 
 
Библиотека алгоритмов
Ограниченные алгоритмы и алгоритмы над диапазонами(C++20)
Ограниченные алгоритмы, например ranges::copy, ranges::sort, ...
Политики исполнения (C++17)
Немодифицирующие операции над последовательностями
(C++11)(C++11)(C++11)
(C++17)
Модифицирующие операции над последовательностями
Операции разбиения
Операции сортировки
Операции двоичного поиска
Операции с наборами (в отсортированных диапазонах)
Операции с кучей
(C++11)
Операций минимума/максимума
min_element
(C++11)
(C++17)

Операции перестановки
Числовые операции
Операции с неинициализированной памятью
(C++17)
(C++17)
(C++17)
Библиотека C
 
Определено в заголовочном файле <algorithm>
template<class ForwardIt >
ForwardIt min_element( ForwardIt first, ForwardIt last );
(1)
template<class ForwardIt, class Compare >
ForwardIt min_element( ForwardIt first, ForwardIt last, Compare comp );
(2)

Находит наименьший элемент в диапазоне [first, last). Первая версия использует operator< для сравнения значений, вторая — переданную функцию сравнения comp.

Содержание

[править]Параметры

first, last однонаправленные итераторы, задающие диапазон
cmp объект функции сравнения (т.е. объект, удовлетворяющий требованиям Compare), который возвращает true, если *aменьше чем *b.

Определение сравнения должно быть эквивалентно:

bool cmp(const Type1 &a, const Type2 &b);

Использование noexcept(начиная с C++11) желательно но не обязательно. Параметры не обязаны передаваться по const&, но не должны модифицироваться. Они должны быть способны принимать все значения типа (даже const) Type1 и Type2 независимо от категории значений (таким образом, Type1& не допускается, равно как и Type1, если только для Type1 перемещение не эквивалентно копированию(начиная с C++11)). Типы Type1 и Type2 должны быть таковы, что объект типа ForwardIt может быть разыменован и затем неявно преобразован в оба из них.

Требования к типам
-
ForwardIt должен соответствовать требованиям ForwardIterator.

[править]Возвращаемое значение

Итератор, указавающий на наименьший элемент в диапазоне [first, last). Если несколько элементов в диапазоне эквивалентны наименьшему, то возвращается итератор на первый такой элемент. Возвращает last, если диапазон пуст.

[править]Сложность

В точности max(N-1,0) сравнений, где N =std::distance(first, last).

[править]Возможная реализация

Первый вариант
template<class ForwardIt> ForwardIt min_element(ForwardIt first, ForwardIt last){if(first == last)return last;   ForwardIt smallest = first;++first;for(; first != last;++first){if(*first <*smallest){ smallest = first;}}return smallest;}
Второй вариант
template<class ForwardIt, class Compare> ForwardIt min_element(ForwardIt first, ForwardIt last, Compare comp){if(first == last)return last;   ForwardIt smallest = first;++first;for(; first != last;++first){if(comp(*first, *smallest)){ smallest = first;}}return smallest;}

[править]Пример

#include <algorithm>#include <iostream>#include <vector>   int main(){std::vector<int> v{3, 1, 4, 1, 5, 9};   std::vector<int>::iterator result = std::min_element(v.begin(), v.end());std::cout<<"min element at: "<<std::distance(v.begin(), result);}

Вывод:

min element at: 1

[править]См. также

возвращает наибольший элемент в диапазоне
(шаблон функции)[править]
возвращает наименьший и наибольший элементы в диапазоне
(шаблон функции)[править]
возвращает меньшее из заданных значений
(шаблон функции)[править]
close