método multiset value_comp() en C++ STL

El std::multiset::value_comp es una función incorporada en C++ STL que devuelve una copia del objeto de comparación utilizado por el contenedor. De forma predeterminada, este es un objeto menos, que devuelve lo mismo que el operador ‘<‘. Es un puntero de función o un objeto de función que toma dos argumentos del mismo tipo que los elementos del contenedor y devuelve verdadero si se considera que el primer argumento va antes del segundo en el estricto orden débil que define o falso de lo contrario. Dos claves se consideran equivalentes si key_comp devuelve false de forma reflexiva (es decir, sin importar el orden en que se pasan las claves como argumentos).

Sintaxis:

value_compare multiset_name.value_comp() 

Parámetros: Esta función no acepta ningún parámetro.

Valor devuelto: la función devuelve una copia del objeto de comparación utilizado por el contenedor.

Los siguientes ejemplos ilustran el método anterior:

Ejemplo 1:

// C++ program to illustrate the
// multiset::value_comp() function
  
#include <bits/stdc++.h>
using namespace std;
  
int main()
{
  
    // Creating a multiset named m;
    multiset<int> m;
  
    multiset<int>::value_compare
        comp
        = m.value_comp();
  
    // Inserting elements into multiset
    m.insert(10);
    m.insert(20);
    m.insert(30);
    m.insert(40);
  
    cout << "Multiset has the elements\n";
  
    // Store key value of last element
    int highest = *m.rbegin();
  
    // initializing the iterator
    multiset<int>::iterator it = m.begin();
  
    // printing elements of all multiset
    do {
  
        cout << " " << *it;
  
    } while (comp(*it++, highest));
  
    return 0;
}
Producción:

Multiset has the elements
 10 20 30 40

Ejemplo 2:

// C++ program to illustrate the
// multiset::value_comp() function
  
#include <bits/stdc++.h>
using namespace std;
  
int main()
{
  
    // Creating a multiset named m;
    multiset<int> m;
  
    multiset<int>::value_compare
        comp
        = m.value_comp();
  
    // Inserting elements into multiset
    m.insert(100);
    m.insert(200);
    m.insert(300);
    m.insert(400);
  
    cout << "Multiset has the elements\n";
  
    // Store key value of last element
    int highest = *m.rbegin();
  
    // initializing the iterator
    multiset<int>::iterator it = m.begin();
  
    // printing elements of all multiset
    do {
  
        cout << " " << *it;
  
    } while (comp(*it++, highest));
  
    return 0;
}
Producción:

Multiset has the elements
 100 200 300 400

Publicación traducida automáticamente

Artículo escrito por ankit15697 y traducido por Barcelona Geeks. The original can be accessed here. Licence: CCBY-SA

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *