El ‘=’ es un operador en C++ STL que copia (o mueve) un conjunto múltiple sin ordenar a otro conjunto múltiple sin ordenar y un conjunto múltiple sin ordenar::operator= es la función de operador correspondiente. Hay tres versiones de esta función:
- La primera versión toma como referencia un multiconjunto sin ordenar como argumento y lo copia en un multiconjunto sin ordenar. Sintaxis:
ums1.operator=(unordered_multiset &ums2)
- Parámetros: La primera versión toma la referencia de un unordered_multiset como argumento.
- La segunda versión realiza una asignación de movimiento, es decir, mueve el contenido de un conjunto múltiple sin ordenar a otro conjunto múltiple sin ordenar. Sintaxis:
ums1.operator=(unordered_multiset &&ums2)
- Parámetros: la segunda versión toma la referencia del valor r de un conjunto múltiple sin ordenar como argumento
- La tercera versión asigna el contenido de una lista de inicializadores a un conjunto múltiple sin ordenar. Sintaxis:
ums1.operator=(initializer list)
- Parámetros: La tercera versión toma una lista de inicializadores como argumento.
Valor devuelto: Todos ellos devuelven el valor de este puntero(*this). El siguiente programa ilustra unordered_multiset::operator= .
CPP
// C++ code to illustrate the method // unordered_multiset::operator=() #include <iostream> #include <unordered_set> using namespace std; // merge function template <class T> T merge(T a, T b) { T t(a); t.insert(b.begin(), b.end()); return t; } int main() { unordered_multiset<int> sample1, sample2, sample3; // List initialization sample1 = { 1, 2, 2, 3, 3, 4, 4, 4, 3, 4 }; sample2 = { 1, 2, 3, 1, 4 }; // Merge both unordered_multisets and // move the result to sample1 sample3 = merge(sample1, sample2); // copy assignment sample1 = sample3; // Print the unordered_set list for (auto it = sample1.begin(); it != sample1.end(); ++it) cout << *it << " "; cout << endl; for (auto it = sample2.begin(); it != sample2.end(); ++it) cout << *it << " "; cout << endl; for (auto it = sample3.begin(); it != sample3.end(); ++it) cout << *it << " "; cout << endl; }
Producción:
1 1 1 2 2 2 3 3 3 3 4 4 4 4 4 4 3 2 1 1 1 1 1 2 2 2 3 3 3 3 4 4 4 4 4
Tiempo Complejidad-O(N)
Publicación traducida automáticamente
Artículo escrito por tufan_gupta2000 y traducido por Barcelona Geeks. The original can be accessed here. Licence: CCBY-SA