std::minmax — cppreference.com
De cppreference.com
<metanoindex/>
<tbody> </tbody>
| Déclaré dans l'en-tête <algorithm> |
||
|
|
(1) | (depuis C++11) |
|
|
(2) | (depuis C++11) |
|
|
(3) | (depuis C++11) |
|
|
(4) | (depuis C++11) |
1-2)
Retourne le plus petit et le plus grand des deux valeurs .
Original:
Returns the smaller and the greater of the two values.
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
3-4)
Retourne la liste la plus petite et la plus grande des valeurs dans l'initialiseur ilist .
Original:
Returns the smallest and the greatest of the values in initializer list ilist.
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
Les versions (1,3) operator< utiliser pour comparer les valeurs, tandis que les versions (2,4) utiliser la fonction de comparaison donnée comp .
Original:
The (1,3) versions use operator< to compare the values, whereas the (2,4) versions use the given comparison function comp.
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
Paramètres
| a, b | - | les valeurs de comparaison Original: the values to compare The text has been machine-translated via Google Translate. |
| ilist | - | initialiseur liste avec les valeurs à comparer Original: initializer list with the values to compare The text has been machine-translated via Google Translate. |
| comp | - | comparison function which returns true if if a is less than b.
The signature of the comparison function should be equivalent to the following:
The signature does not need to have |
| Type requirements | ||
-T must meet the requirements of LessThanComparable. for the overloads (1) and (3)
| ||
-T must meet the requirements of CopyConstructible. for the overloads (3) and (4)
| ||
Retourne la valeur
1-2)
Retourne le résultat de std::make_pair(a, b) si a<b ou si a est équivalent à b. Retourne le résultat de std::make_pair(b, a) si b<a .
Original:
Returns the result of std::make_pair(a, b) if a<b or if a is equivalent to b. Returns the result of std::make_pair(b, a) if b<a.
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
3-4)
Une paire avec la plus petite valeur dans ilist que le premier élément et le plus grand que le second. Si plusieurs éléments sont équivalentes à la plus petite, l'élément le plus à gauche telle est retourné. Si plusieurs éléments sont équivalentes au plus grand, l'élément le plus à droite par exemple est retourné .
Original:
A pair with the smallest value in 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.
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
Complexité
1-2)
Constante
Original:
Constant
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
3-4)
Linéaire dans ilist.size()
Original:
Linear in ilist.size()
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
Mise en œuvre possible
| First version |
|---|
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); } |
| Second version |
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); } |
| Third version |
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); } |
| Fourth version |
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); } |
Exemple
#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'; }
Résultat possible :
Voir aussi
retourne le plus petit des deux éléments Original: returns the smaller of two elements The text has been machine-translated via Google Translate. (fonction générique) [edit] | |
retourne le plus grand des deux éléments Original: returns the larger of two elements The text has been machine-translated via Google Translate. (fonction générique) [edit] | |