std::minmax
![]() |
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 T > std::pair<const T&,const T&> minmax( const T& a, const T& b ); |
(1) | (desde C++11) |
template< class T, class Compare > std::pair<const T&,const T&> minmax( const T& a, const T& b, Compare comp ); |
(2) | (desde C++11) |
template< class T > std::pair<T,T> minmax( std::initializer_list<T> ilist); |
(3) | (desde C++11) |
template< class T, class Compare > std::pair<T,T> minmax( std::initializer_list<T> ilist, Compare comp ); |
(4) | (desde C++11) |
You can help to correct and verify the translation. Click here for instructions.
ilist
.ilist
.You can help to correct and verify the translation. Click here for instructions.
comp
.comp
.You can help to correct and verify the translation. Click here for instructions.
Contenido |
[editar] Parámetros
a, b | - | los valores para comparar
Original: the values to compare The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. |
ilist | - | inicializador lista con los valores a comparar
Original: initializer list with the values to compare The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. |
comp | - | 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: bool cmp(const Type1 &a, const Type2 &b); Mientras que la signatura no necesita ser const &, la función no debe modificar los objetos que se le pasaron y debe admitir todos los valores de los tipos (posiblemente |
Requisitos de tipo | ||
-T debe reunir los requerimientos de LessThanComparable . for the overloads (1) and (3)
| ||
-T debe reunir los requerimientos de CopyConstructible . for the overloads (3) and (4)
|
[editar] Valor de retorno
a<b
o si a
es equivalente a b
. Devuelve el resultado de std::make_pair(b, a) si b<a
.a<b
or if a
is equivalent to b
. Returns the result of std::make_pair(b, a) if b<a
.You can help to correct and verify the translation. Click here for instructions.
ilist
como el primer elemento y el más grande como el segundo. Si varios elementos son equivalentes a los más pequeños, el elemento tal extremo izquierdo se devuelve. Si varios elementos son equivalentes a la más grande, el elemento más a la derecha como se devuelve .ilist
as the first element and the greatest as the second. If several elements are equivalent to the smallest, the leftmost such element is returned. If several elements are equivalent to the largest, the rightmost such element is returned.You can help to correct and verify the translation. Click here for instructions.
[editar] Complejidad
You can help to correct and verify the translation. Click here for instructions.
ilist.size()
ilist.size()
You can help to correct and verify the translation. Click here for instructions.
[editar] Posible implementación
Primera versión |
---|
template<class T> std::pair<const T&,const T&> minmax(const T& a, const T& b) { return (b < a) ? std::make_pair(b, a) : std::make_pair(a, b); } |
Segunda versión |
template<class T, class Compare> std::pair<const T&,const T&> minmax(const T& a, const T& b, Compare comp) { return comp(b, a) ? std::make_pair(b, a) : std::make_pair(a, b); } |
Tercera versión |
template< class T > std::pair<T,T> minmax( std::initializer_list ilist) { auto p = std::minmax_element(ilist.begin(), ilist.end()); return std::make_pair(*p.first, *p.second); } |
Cuarta versión |
template< class T, class Compare > std::pair<T,T> minmax( std::initializer_list ilist, Compare comp ) { auto p = std::minmax_element(ilist.begin(), ilist.end(), comp); return std::make_pair(*p.first, *p.second); } |
[editar] Ejemplo
#include <algorithm> #include <iostream> #include <vector> #include <cstdlib> #include <ctime> int main() { std::vector<int> v {3, 1, 4, 1, 5, 9, 2, 6}; std::srand(std::time(0)); std::pair<int,int> bounds = std::minmax(std::rand() % v.size(), std::rand() % v.size()); std::cout << "v[" << bounds.first << "," << bounds.second << "]: "; for (int i = bounds.first; i < bounds.second; ++i) { std::cout << v[i] << ' '; } std::cout << '\n'; }
Posible salida:
v[2,7]: 4 1 5 9 2
[editar] Ver también
Devuelve el menor de los elementos (plantilla de función) | |
Devuelve el mayor de dos elementos (plantilla de función) |