std::lexicographical_compare
![]() | 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 InputIt1, class InputIt2 > bool lexicographical_compare( InputIt1 first1, InputIt1 last1, | (1) | |
template<class InputIt1, class InputIt2, class Compare > bool lexicographical_compare( InputIt1 first1, InputIt1 last1, | (2) | |
comp
.comp
.You can help to correct and verify the translation. Click here for instructions.
You can help to correct and verify the translation. Click here for instructions.
- Dos cadenas se comparan elemento por elemento .Original:Two ranges are compared element by element.The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions. - El elemento descalce primera define qué rango es menos lexicográfico''' o mayor que el otro .Original:The first mismatching element defines which range is lexicographically less or greater than the other.The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions. - Si una serie es un prefijo de otro, el rango más corto es lexicográfico' menos que el otro .Original:If one range is a prefix of another, the shorter range is lexicographically less than the other.The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions. - Si dos gamas tienen elementos equivalentes y son de la misma longitud, entonces los rangos son iguales lexicográficamente' .Original:If two ranges have equivalent elements and are of the same length, then the ranges are lexicographically equal.The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions. - Un rango de vacío es lexicográfico' menos de cualquier rango que no esté vacía .Original:An empty range is lexicographically less than any non-empty range.The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions. - Dos cadenas vacías son lexicográfico' igual .Original:Two empty ranges are lexicographically equal.The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
Contenido |
[editar]Parámetros
first1, last1 | - | la primera gama de elementos a examinar Original: the first range of elements to examine The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. |
first2, last2 | - | la segunda gama de elementos a examinar Original: the second range of elements to examine 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 el primer argumento es menor que el segundo. 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 | ||
-InputIt1, InputIt2 debe reunir los requerimientos de InputIterator . |
[editar]Valor de retorno
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.
[editar]Posible implementación
Primera versión |
---|
template<class InputIt1, class InputIt2>bool lexicographical_compare(InputIt1 first1, InputIt1 last1, InputIt2 first2, InputIt2 last2){for(;(first1 != last1)&&(first2 != last2); first1++, first2++){if(*first1 <*first2)returntrue;if(*first2 <*first1)returnfalse;}return(first1 == last1)&&(first2 != last2);} |
Segunda versión |
template<class InputIt1, class InputIt2, class Compare>bool lexicographical_compare(InputIt1 first1, InputIt1 last1, InputIt2 first2, InputIt2 last2, Compare comp){for(;(first1 != last1)&&(first2 != last2); first1++, first2++){if(comp(*first1, *first2))returntrue;if(comp(*first2, *first1))returnfalse;}return(first1 == last1)&&(first2 != last2);} |
[editar]Ejemplo
#include <algorithm>#include <iostream>#include <vector>#include <cstdlib>#include <ctime> int main(){std::vector<char> v1 {'a', 'b', 'c', 'd'};std::vector<char> v2 {'a', 'b', 'c', 'd'}; std::srand(std::time(0));while(!std::lexicographical_compare(v1.begin(), v1.end(), v2.begin(), v2.end())){for(auto c : v1)std::cout<< c <<' ';std::cout<<">= ";for(auto c : v2)std::cout<< c <<' ';std::cout<<'\n'; std::random_shuffle(v1.begin(), v1.end());std::random_shuffle(v2.begin(), v2.end());} for(auto c : v1)std::cout<< c <<' ';std::cout<<"< ";for(auto c : v2)std::cout<< c <<' ';std::cout<<'\n';}
Posible salida:
a b c d >= a b c d d a b c >= c b d a b d a c >= a d c b a c d b < c d a b