cpp/algorithm/mismatch: differenze tra le versioni
m (r2.7.3) (Bot: Aggiungo de, en, fr, ja, pt, zh) |
m (Use {{lc}}. Update links. Various fixes.) |
||
Riga 2: | Riga 2: | ||
{{cpp/title|mismatch}} | {{cpp/title|mismatch}} | ||
{{cpp/algorithm/navbar}} | {{cpp/algorithm/navbar}} | ||
− | {{ | + | {{begin}} |
− | {{ | + | {{header | algorithm}} |
− | {{ | + | {{| num=1 | |
template< class InputIt1, class InputIt2 > | template< class InputIt1, class InputIt2 > | ||
std::pair<InputIt1,InputIt2> | std::pair<InputIt1,InputIt2> | ||
Riga 11: | Riga 11: | ||
InputIt2 first2 ); | InputIt2 first2 ); | ||
}} | }} | ||
− | {{ | + | {{| num=2 | |
template< class InputIt1, class InputIt2, class BinaryPredicate > | template< class InputIt1, class InputIt2, class BinaryPredicate > | ||
std::pair<InputIt1,InputIt2> | std::pair<InputIt1,InputIt2> | ||
Riga 19: | Riga 19: | ||
BinaryPredicate p ); | BinaryPredicate p ); | ||
}} | }} | ||
− | {{ | + | {{end}} |
{{tr|Restituisce la prima coppia di elementi di mismatching da due gruppi: quello definito dalla {{tt|[first1, last1)}} e un altro a partire da {{tt|first2}}. La prima versione della funzione utilizza {{tt|operator{{==}}}} per confrontare gli elementi, la seconda versione utilizza il predicato binario dato {{tt|p}}. |Returns the first mismatching pair of elements from two ranges: one defined by {{tt|[first1, last1)}} and another starting at {{tt|first2}}. The first version of the function uses {{tt|operator{{==}}}} to compare the elements, the second version uses the given binary predicate {{tt|p}}. }} | {{tr|Restituisce la prima coppia di elementi di mismatching da due gruppi: quello definito dalla {{tt|[first1, last1)}} e un altro a partire da {{tt|first2}}. La prima versione della funzione utilizza {{tt|operator{{==}}}} per confrontare gli elementi, la seconda versione utilizza il predicato binario dato {{tt|p}}. |Returns the first mismatching pair of elements from two ranges: one defined by {{tt|[first1, last1)}} and another starting at {{tt|first2}}. The first version of the function uses {{tt|operator{{==}}}} to compare the elements, the second version uses the given binary predicate {{tt|p}}. }} | ||
===Parametri=== | ===Parametri=== | ||
− | {{ | + | {{begin}} |
− | {{ | + | {{| first1, last1 |{{tr| la prima serie di elementi| the first range of the elements}}}} |
− | {{ | + | {{| first2 |{{tr| all'inizio del secondo intervallo di elementi| the beginning of the second range of the elements}}}} |
− | {{ | + | {{pred2 eq | p | p1=InputIt1 | p2=InputIt2}} |
− | {{ | + | {{hreq}} |
− | {{ | + | {{req concept | InputIt1 | InputIterator}} |
− | {{ | + | {{req concept | InputIt2 | InputIterator}} |
− | {{ | + | {{req concept | OutputIt | OutputIterator}} |
− | {{ | + | {{end}} |
===Valore di ritorno=== | ===Valore di ritorno=== | ||
− | {{tr|{{ | + | {{tr|{{|std::pair}} con iteratori alle prime due non equivalenti elementi, o, in mancanza di elementi diversi trovato, coppia con {{tt|last1}} e l'iteratore corrispondente dal secondo intervallo.|{{|std::pair}} with iterators to the first two non-equivalent elements, or, if no different elements found, pair with {{tt|last1}} and the corresponding iterator from the second range.}} |
===Complessità=== | ===Complessità=== | ||
Riga 92: | Riga 92: | ||
===Vedi anche=== | ===Vedi anche=== | ||
− | {{ | + | {{begin}} |
− | {{ | + | {{| cpp/algorithm/equal}} |
− | {{ | + | {{| cpp/algorithm/find}} |
− | {{ | + | {{| cpp/algorithm/lexicographical_compare}} |
− | {{ | + | {{| cpp/algorithm/search}} |
− | {{ | + | {{end}} |
[[de:cpp/algorithm/mismatch]] | [[de:cpp/algorithm/mismatch]] |
Versione attuale delle 12:23, 2 lug 2013
![]() |
Questa pagina è stata tradotta in modo automatico dalla versione in ineglese della wiki usando Google Translate.
La traduzione potrebbe contenere errori e termini strani. Muovi il puntatore sopra al testo per vedere la versione originale. Puoi aiutarci a correggere gli gli errori. Per ulteriori istruzioni clicca qui. |
Elemento definito nell'header <algorithm>
|
||
template< class InputIt1, class InputIt2 > std::pair<InputIt1,InputIt2> |
(1) | |
template< class InputIt1, class InputIt2, class BinaryPredicate > std::pair<InputIt1,InputIt2> |
(2) | |
[first1, last1)
e un altro a partire da first2
. La prima versione della funzione utilizza operator==
per confrontare gli elementi, la seconda versione utilizza il predicato binario dato p
. [first1, last1)
and another starting at first2
. The first version of the function uses operator==
to compare the elements, the second version uses the given binary predicate p
. You can help to correct and verify the translation. Click here for instructions.
Indice |
[modifica] Parametri
first1, last1 | - | la prima serie di elementi
Original: the first range of the elements The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. |
first2 | - | all'inizio del secondo intervallo di elementi
Original: the beginning of the second range of the elements The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. |
p | - | binary predicate which returns true if the elements should be treated as equal. The signature of the predicate function should be equivalent to the following: bool pred(const Type1 &a, const Type2 &b); The signature does not need to have const &, but the function must not modify the objects passed to it. |
Type requirements | ||
-InputIt1 must meet the requirements of InputIterator .
| ||
-InputIt2 must meet the requirements of InputIterator .
| ||
-OutputIt must meet the requirements of OutputIterator .
|
[modifica] Valore di ritorno
last1
e l'iteratore corrispondente dal secondo intervallo.last1
and the corresponding iterator from the second range.You can help to correct and verify the translation. Click here for instructions.
[modifica] Complessità
last1
- first1
applicazioni del predicatolast1
- first1
applications of the predicateYou can help to correct and verify the translation. Click here for instructions.
[modifica] Possibile implementazione
First version |
---|
template<class InputIt1, class InputIt2> std::pair<InputIt1, InputIt2> mismatch(InputIt1 first1, InputIt1 last1, InputIt2 first2) { while (first1 != last1 && *first1 == *first2) { ++first1, ++first2; } return std::make_pair(first1, first2); } |
Second version |
template<class InputIt1, class InputIt2, class BinaryPredicate> std::pair<InputIt1, InputIt2> mismatch(InputIt1 first1, InputIt1 last1, InputIt2 first2, BinaryPredicate p) { while (first1 != last1 && p(*first1, *first2)) { ++first1, ++first2; } return std::make_pair(first1, first2); } |
[modifica] Esempio
You can help to correct and verify the translation. Click here for instructions.
#include <iostream> #include <string> #include <algorithm> std::string mirror_ends(const std::string& in) { return std::string(in.begin(), std::mismatch(in.begin(), in.end(), in.rbegin()).first); } int main() { std::cout << mirror_ends("abXYZba") << '\n' << mirror_ends("abca") << '\n' << mirror_ends("aba") << '\n'; }
Output:
ab a aba
[modifica] Vedi anche
determina se due serie di elementi sono gli stessi Original: determines if two sets of elements are the same The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. (funzione di modello) | |
(C++11) |
trova il primo elemento che soddisfi i criteri specifici Original: finds the first element satisfying specific criteria The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. (funzione di modello) |
restituisce true se un intervallo è lessicograficamente minore di un altro Original: returns true if one range is lexicographically less than another The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. (funzione di modello) | |
searches for a range of elements (funzione di modello) |