Condividi tramite


hash_set::insert

[!NOTA]

Questo API è obsoleto.L'alternativa consiste unordered_set Class.

Inserire un elemento o un intervallo di elementi in hash_set.

pair<iterator, bool> insert(
   const value_type& _Val
);
iterator insert(
   iterator _Where,
   const value_type& _Val
);
template<class InputIterator>
   void insert(
      InputIterator _First,
      InputIterator _Last
);

Parametri

Parametro

Descrizione

_Val

Il valore di un elemento da inserire in hash_set a meno che hash_set già contenere più generale tale elemento, o, un elemento il cui la chiave equivalente è ordinata.

_Where

Il posto per avviare ricerca il punto corretto di inserimento.(Inserimento può verificarsi nel tempo costante ammortizzato, anziché tempo logaritmico, se il punto di inserimento immediatamente successivo a _Where).

_First

La posizione del primo elemento da hash_set.

_Last

La posizione solo oltre l'ultimo elemento da hash_set.

Valore restituito

La prima funzione membro insert restituisce una coppia di cui il componente bool restituisce true se un inserimento è stato e viene false se hash_set già contiene un elemento il cui la chiave ha un valore equivalente in ordine e di cui il componente iteratori restituisce l'indirizzo dove un nuovo elemento è stato inserito o in cui l'elemento è già stato individuato.

Per accedere al componente iteratore di una coppia pr restituito dalla funzione membro, utilizzare pr.firste per dereferenziarla, l'utilizzo *(pr.first).Per accedere al componente bool di una coppia pr restituito dalla funzione membro, utilizzare pr.seconde per dereferenziarla, utilizzare *(pr.second).

La seconda funzione membro insert restituisce un iteratore che indica la posizione in cui il nuovo elemento è stato immesso in hash_set.

Note

La terza funzione membro inserire la sequenza di valori degli elementi in hash_set corrispondente a ogni elemento indirizzato mediante un iteratore nell'intervallo [_First, _Last) hash_setspecificato.

Esempio

// hash_set_insert.cpp
// compile with: /EHsc
#include <hash_set>
#include <iostream>

int main( )
{
   using namespace std;
   using namespace stdext;
   hash_set <int>::iterator hs1_pIter, hs2_pIter;

   hash_set <int, hash_compare <int, less<int> > > hs1, hs2;
   hs1.insert( 10 );
   hs1.insert( 20 );
   hs1.insert( 30 );
   hs1.insert( 40 );

   cout << "The original hs1 =";
   for ( hs1_pIter = hs1.begin( ); hs1_pIter != hs1.end( );
         hs1_pIter++ )
      cout << " " << *hs1_pIter;
   cout << "." << endl;

   pair< hash_set<int>::iterator, bool > pr;
   pr = hs1.insert( 10 );

   if(pr.second == true)
   {
      cout << "The element 10 was inserted in hs1 successfully."
           << endl;
   }
   else
   {
      cout << "The element 10 already exists in hs1 and"
           << " *( pr.first ) = " << *( pr.first ) << "."
           << endl;
   }

   hs1.insert( --hs1.end( ), 50 );

   cout << "After the insertions, hs1 =";
   for ( hs1_pIter = hs1.begin( ); hs1_pIter != hs1.end( );
         hs1_pIter++ )
      cout << " " << *hs1_pIter;
   cout << "." << endl;

   hs2.insert( 100 );
   hs2.insert( ++hs1.begin( ), --hs1.end( ) );

   cout << "hs2 =";
   for ( hs2_pIter = hs2.begin( ); hs2_pIter != hs2.end( );
         hs2_pIter++ )
      cout << " " << *hs2_pIter;
   cout << "." << endl;
}
  
  
  
  

Requisiti

intestazione: <hash_set>

Stdext diSpazio dei nomi:

Vedere anche

Riferimenti

hash_set Class

Libreria di modelli standard