std:: minmax
|
Definido en el encabezado
<algorithm>
|
||
|
template
<
class
T
>
std:: pair < const T & , const T & > minmax ( const T & a, const T & b ) ; |
(1) |
(desde C++11)
(constexpr desde C++14) |
|
template
<
class
T,
class
Compare
>
std::
pair
<
const
T
&
,
const
T
&
>
minmax
(
const
T
&
a,
const
T
&
b,
|
(2) |
(desde C++11)
(constexpr desde C++14) |
|
template
<
class
T
>
std:: pair < T, T > minmax ( std:: initializer_list < T > ilist ) ; |
(3) |
(desde C++11)
(constexpr desde C++14) |
|
template
<
class
T,
class
Compare
>
std::
pair
<
T, T
>
minmax
(
std::
initializer_list
<
T
>
ilist,
|
(4) |
(desde C++11)
(constexpr desde C++14) |
Devuelve el menor y el mayor de los valores dados.
Contenidos |
Parámetros
| a, b | - | los valores a comparar |
| ilist | - | lista de inicializadores con los valores a comparar |
| comp | - |
objeto función de comparación (es decir, un objeto que cumple con los requisitos de
Compare
) que devuelve
true
si el primer argumento es
menor
que el segundo.
La firma de la función de comparación debe ser equivalente a la siguiente: bool cmp ( const Type1 & a, const Type2 & b ) ;
Aunque la firma no necesita tener
const
&
, la función no debe modificar los objetos pasados a ella y debe poder aceptar todos los valores de tipo (posiblemente const)
|
Valor de retorno
Complejidad
| 3N |
| 2 |
| 3N |
| 2 |
Implementación posible
| minmax (1) |
|---|
| minmax (2) |
| minmax (3) |
template<class T> constexpr std::pair<T, T> minmax(std::initializer_list<T> ilist) { auto p = std::minmax_element(ilist.begin(), ilist.end()); return std::pair(*p.first, *p.second); } |
| minmax (4) |
template<class T, class Compare> constexpr std::pair<T, T> minmax(std::initializer_list<T> ilist, Compare comp) { auto p = std::minmax_element(ilist.begin(), ilist.end(), comp); return std::pair(*p.first, *p.second); } |
Notas
Para las sobrecargas
(
1,2
)
, si uno de los parámetros es un temporal, la referencia devuelta se convierte en una referencia colgante al final de la expresión completa que contiene la llamada a
minmax
:
int n = 1; auto p = std::minmax(n, n + 1); int m = p.first; // correcto int x = p.second; // comportamiento indefinido // Nótese que los enlaces estructurados presentan el mismo problema auto [mm, xx] = std::minmax(n, n + 1); xx; // comportamiento indefinido
Ejemplo
#include <algorithm> #include <cstdlib> #include <ctime> #include <iostream> #include <vector> 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'; }
Salida posible:
v[2,7]: 4 1 5 9 2
Informes de defectos
Los siguientes informes de defectos que modifican el comportamiento se aplicaron retroactivamente a los estándares de C++ publicados anteriormente.
| DR | Aplicado a | Comportamiento publicado | Comportamiento correcto |
|---|---|---|---|
| LWG 2239 | C++11 |
T
se requería que fuera
LessThanComparable
para las sobrecargas
(
2,4
)
|
no requerido |
Véase también
|
devuelve el menor de los valores dados
(plantilla de función) |
|
|
devuelve el mayor de los valores dados
(plantilla de función) |
|
|
(C++11)
|
devuelve los elementos menor y mayor en un rango
(plantilla de función) |
|
(C++20)
|
devuelve el elemento menor y mayor de dos elementos
(objeto función de algoritmo) |