std::set_union
|  | 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. | 
| Defined in header <algorithm>
  | ||
| template< class InputIt1, class InputIt2, class OutputIt > OutputIt set_union( InputIt1 first1, InputIt1 last1, | (1) | |
| template< class InputIt1, class InputIt2,           class OutputIt, class Compare > | (2) | |
d_first costituito da tutti gli elementi presenti in una o entrambe le gamme filtrate [first1, last1) e [first2, last2). La prima versione si aspetta che sia l'ingresso che varia da ordinare con operator<, la seconda versione si aspetta che essere ordinati con il confronto comp data funzione. Se qualche elemento si trova m volte in [first1, last1) e n volte in [first2, last2), quindi tutti gli elementi m verranno copiati dal [first1, last1) a d_first, mantenere l'ordine, e poi esattamente std::max(n-m, 0) elementi verranno copiati dal [first2, last2) a d_first, anche mantenere l'ordine. L'intervallo risultante non possono sovrapporsi uno dei campi di ingresso.d_first consisting of all elements present in one or both sorted ranges [first1, last1) and [first2, last2). The first version expects both input ranges to be sorted with operator<, the second version expects them to be sorted with the given comparison function comp. If some element is found m times in [first1, last1) and n times in [first2, last2), then all m elements will be copied from [first1, last1) to d_first, preserving order, and then exactly std::max(n-m, 0) elements will be copied from [first2, last2) to d_first, also preserving order. The resulting range cannot overlap with either of the input ranges.You can help to correct and verify the translation. Click here for instructions.
| Indice | 
[modifica] Parametri
| first1, last1 | - |  il primo ingresso ordinato gamma Original:  the first input sorted range The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. | 
| first2, last2 | - |  il secondo ingresso ordinato gamma Original:  the second input sorted range The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. | 
| comp | - | comparison function which returns true if the first argument is less than the second. The signature of the comparison function should be equivalent to the following: bool cmp(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 | ||
| - InputIt1must meet the requirements ofInputIterator. | ||
| - InputIt2must meet the requirements ofInputIterator. | ||
| - OutputItmust meet the requirements ofOutputIterator. | ||
[modifica] Valore di ritorno
You can help to correct and verify the translation. Click here for instructions.
[modifica] Complessità
You can help to correct and verify the translation. Click here for instructions.
[modifica] Possibile implementazione
| First version | 
|---|
| template<class InputIt1, class InputIt2, class OutputIt> OutputIt set_union(InputIt1 first1, InputIt1 last1, InputIt2 first2, InputIt2 last2, OutputIt d_first) { for (; first1 != last1; ++d_first) { if (first2 == last2) return std::copy(first1, last1, d_first); if (*first2 < *first1) { *d_first = *first2++; } else { *d_first = *first1; if (!(*first1 < *first2)) ++first2; ++first1; } } return std::copy(first2, last2, d_first); } | 
| Second version | 
| template<class InputIt1, class InputIt2, class OutputIt, class Compare> OutputIt set_union(InputIt1 first1, InputIt1 last1, InputIt2 first2, InputIt2 last2, OutputIt d_first, Compare comp) { for (; first1 != last1; ++d_first) { if (first2 == last2) return std::copy(first1, last1, d_first); if (comp(*first2, *first1)) { *d_first = *first2++; } else { *d_first = *first1; if (!comp(*first1, *first2)) ++first2; ++first1; } } return std::copy(first2, last2, d_first); } | 
[modifica] Esempio
| This section is incomplete Reason: no example | 
[modifica] Vedi anche
|  restituisce true se un insieme è un sottoinsieme di un altro  Original:  returns true if one set is a subset of 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) | |
|  calcola la differenza tra due insiemi  Original:  computes the difference between two sets  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) | |
|  calcola l'intersezione di due insiemi  Original:  computes the intersection of two sets  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) | |
|  calcola la differenza simmetrica tra due insiemi  Original:  computes the symmetric difference between two sets  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) | |


