list::assign (STL Samples)
Ilustra como usar o list::assign função de biblioteca STL (Standard Template) no Visual C++.
void assign(
const_iterator First,
const_iterator Last
);
void assign(
size_type n,
const T& x = T( )
);
iterator erase(
iterator It
);
iterator erase(
iterator First,
iterator Last
); bool empty( ) const;
Comentários
Observação |
---|
Nomes de classe/parâmetro o protótipo não coincidem com a versão no arquivo de cabeçalho.Alguns foram modificados para melhorar a legibilidade. |
A primeira função de membro substitui a seqüência controlada por *Este com a seqüência [First, Last).A segunda função de membro substitui a seqüência controlada por *Este com uma repetição de n elementos de valor x.A terceira função de membro remove o elemento da seqüência controlado apontada por -.A função de membro quarta remove os elementos da seqüência controlado no intervalo [First, Last).Os dois retornam um iterador que designa o primeiro elemento restantes além quaisquer elementos removidos, ou final se não há tal elemento existe.A última função de membro retorna true para uma seqüência vazia de controlado.
Exemplo
// assign.cpp
// compile with: /EHsc
//
// Shows various ways to assign and erase elements
// from a list<T>.
//
// Functions:
// list::assign
// list::empty
// list::erase
#include <list>
#include <iostream>
using namespace std ;
typedef list<int> LISTINT;
int main()
{
LISTINT listOne;
LISTINT listAnother;
LISTINT::iterator i;
// Add some data
listOne.push_front (2);
listOne.push_front (1);
listOne.push_back (3);
listAnother.push_front(4);
listAnother.assign(listOne.begin(), listOne.end());
// 1 2 3
for (i = listAnother.begin(); i != listAnother.end(); ++i)
cout << *i << " ";
cout << endl;
listAnother.assign(4, 1);
// 1 1 1 1
for (i = listAnother.begin(); i != listAnother.end(); ++i)
cout << *i << " ";
cout << endl;
listAnother.erase(listAnother.begin());
// 1 1 1
for (i = listAnother.begin(); i != listAnother.end(); ++i)
cout << *i << " ";
cout << endl;
listAnother.erase(listAnother.begin(), listAnother.end());
if (listAnother.empty())
cout << "All gone\n";
}
Saída
1 2 3
1 1 1 1
1 1 1
All gone
Requisitos
Cabeçalho: <list>