std::minmax_element
|
|
Esta página se ha traducido por ordenador/computador/computadora de la versión en inglés de la Wiki usando Google Translate.
La traducción puede contener errores y palabras aparatosas/incorrectas. Planea sobre el texto para ver la versión original. Puedes ayudar a corregir los errores y mejorar la traducción. Para instrucciones haz clic aquí. |
| Definido en el archivo de encabezado <algorithm>
|
||
template< class ForwardIt > std::pair<ForwardIt,ForwardIt> minmax_element( ForwardIt first, ForwardIt last ); |
(1) | |
template< class ForwardIt, class Compare > std::pair<ForwardIt,ForwardIt> minmax_element( ForwardIt first, ForwardIt last, Compare comp ); |
(2) | |
[first, last) rango. La primera versión utiliza operator< para comparar los valores, la segunda versión utiliza la función de comparación dado comp .[first, last). The first version uses operator< to compare the values, the second version uses the given comparison function comp.You can help to correct and verify the translation. Click here for instructions.
Parámetros
| first, last | - | iteradores hacia adelante que definen el rango de examinar
Original: forward iterators defining the range to examine The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. |
| cmp | - | objeto función de comparación (es decir, un objeto que satisface los requerimientos de Compare) que devuelve true si if *a is less than *b. La signatura de la función de comparación deberá ser equivalente a lo siguiente:
Mientras que la signatura no necesita ser |
| Requisitos de tipo | ||
-ForwardIt debe reunir los requerimientos de ForwardIterator.
| ||
Valor de retorno
std::make_pair(first, first) si el rango está vacía. Si varios elementos son equivalentes para el elemento más pequeño, el iterador al elemento tal primero se devuelve. Si varios elementos son equivalentes para el elemento más grande, el iterador al elemento tal se devolverá el último .std::make_pair(first, first) if the range is empty. If several elements are equivalent to the smallest element, the iterator to the first such element is returned. If several elements are equivalent to the largest element, the iterator to the last such element is returned.You can help to correct and verify the translation. Click here for instructions.
Complejidad
N = std::distance(first, last) .N = std::distance(first, last).You can help to correct and verify the translation. Click here for instructions.
Posible implementación
| Primera versión |
|---|
template<class ForwardIt>
std::pair<ForwardIt, ForwardIt>
minmax_element(ForwardIt first, ForwardIt last)
{
typedef typename std::iterator_traits<ForwardIt>::value_type value_t;
return std::minmax_element(first, last, std::less<value_t>());
}
|
| Segunda versión |
template<class ForwardIt, class Compare>
std::pair<ForwardIt, ForwardIt>
minmax_element(ForwardIt first, ForwardIt last, Compare comp)
{
std::pair<ForwardIt, ForwardIt> result(first, first);
if (first == last) return result;
if (++first == last) return result;
if (comp(*first, *result.first)) {
result.second = result.first;
result.first = first;
} else {
result.second = first;
}
while (++first != last) {
ForwardIt i = first;
if (++first == last) {
if (comp(*i, *result.first)) result.first = i;
else if (!(comp(*i, *result.second))) result.second = i;
break;
} else {
if (comp(*first, *i)) {
if (comp(*first, *result.first)) result.first = first;
if (!(comp(*i, *result.second))) result.second = i;
} else {
if (comp(*i, *result.first)) result.first = i;
if (!(comp(*first, *result.second))) result.second = first;
}
}
}
return result;
}
|
Ejemplo
#include <algorithm>
#include <iostream>
#include <vector>
int main()
{
std::vector<int> v = { 3, 9, 1, 4, 2, 5, 9 };
auto result = std::minmax_element(v.begin(), v.end());
std::cout << "min element at: " << (result.first - v.begin()) << '\n';
std::cout << "max element at: " << (result.second - v.begin()) << '\n';
}
Salida:
min element at: 2
max element at: 6
Ver también
| Devuelve el elemento más pequeño de un rango. (plantilla de función) | |
| Devuelve el elemento más grande en un rango. (plantilla de función) |