std::list em C++ com exemplo
O que é uma std::lista?
Em C++, o std::list refere-se a um contêiner de armazenamento. O std:list permite inserir e remover itens de qualquer lugar. O std::list é implementado como uma lista duplamente ligada. Isso significa que os dados da lista podem ser acessados bidirecionalmente e sequencialmente.
A lista da Biblioteca de modelos padrão não oferece suporte ao acesso aleatório rápido, mas oferece suporte ao acesso sequencial de todas as direções.
Você pode espalhar elementos de lista em diferentes blocos de memória. As informações necessárias para o acesso sequencial aos dados são armazenadas em um contêiner. O std::list pode expandir e diminuir de ambas as extremidades conforme necessário durante o tempo de execução. Um alocador interno atende automaticamente aos requisitos de armazenamento.
Neste tutorial de C++, você aprenderá:
- O que é uma std::lista?
- Por que usar std::list?
- Sintaxe da lista
- Funções de lista C++
- Construtores
- Propriedades do contêiner
- Inserindo em uma lista
- Exclusão de uma lista
Por que usar std::list?
Aqui estão os motivos para usar std::List :
- O std::list se compara melhor a outros contêineres de sequência, como array e vetor.
- Têm um melhor desempenho na inserção, movimentação e extração de elementos de qualquer posição.
- O std::list também funciona melhor com algoritmos que executam essas operações de forma intensiva.
Sintaxe da lista
Para definir o std::list, temos que importar o arquivo de cabeçalho
- . Aqui está a sintaxe de definição std::list:
- T – Define o tipo de elemento contido.
Você pode substituir T por qualquer tipo de dados, mesmo tipos definidos pelo usuário.
- Alloc – Define o tipo do objeto alocador.
Isso usa o modelo de classe do alocador por padrão. É dependente de valor e usa um modelo simples de alocação de memória.
- Inclua o arquivo de cabeçalho do algoritmo para usar suas funções.
- Inclua o arquivo de cabeçalho iostream para usar suas funções.
- Inclua o arquivo de cabeçalho da lista para usar suas funções.
- Chame a função main(). A lógica do programa deve ser adicionada no corpo desta função.
- Crie uma lista chamada my_list com um conjunto de 4 inteiros.
- Use um loop for para criar uma variável de loop x. Esta variável será usada para iterar sobre os elementos da lista.
- Imprima os valores da lista no console.
- Fim do corpo do for a loop.
- Fim do corpo da função main().
- Construtor padrão std::list::list()- Cria uma lista vazia, que, com zero elementos.
- Construtor de preenchimento std::list::list()- Cria uma lista com n elementos e atribui um valor zero (0) a cada elemento.
- Construtor de intervalo std::list::list()- cria uma lista com muitos elementos no intervalo do primeiro ao último.
- Copiar construtor std::list::list()- Cria uma lista com uma cópia de cada elemento contido na lista existente.
- Move construtor std::list::list()- cria uma lista com os elementos de outra lista usando a semântica de movimento.
- Construtor de lista inicializador std::list::list()-Cria uma lista com os elementos de outra lista usando a semântica de movimento.
- Inclua o arquivo de cabeçalho iostream para usar suas funções.
- Inclua o arquivo de cabeçalho da lista para usar suas funções.
- Inclua o namespace std no código para usar suas classes sem chamá-lo.
- Chame a função main(). A lógica do programa deve ser adicionada no corpo desta função.
- Crie uma lista vazia chamada l.
- Crie uma lista chamada l1 com um conjunto de 3 inteiros.
- Crie uma lista chamada l2 com todos os elementos da lista chamados l1, do início ao fim.
- Crie uma lista chamada l3 usando a semântica de movimento. A lista l3 terá o mesmo conteúdo da lista l2.
- Imprima o tamanho da lista chamada l no console junto com outro texto.
- Imprima algum texto no console.
- Crie um iterador com o nome dele e use-o para iterar sobre os elementos da lista com o nome l2.
- Imprima os elementos da lista chamada l2 no console.
- Imprima algum texto no console.
- Crie um iterador chamado it e use-o para iterar sobre os elementos da lista chamada l3.
- Imprima os elementos da lista chamada l3 no console.
- O programa deve retornar o valor após a conclusão bem-sucedida.
- Fim do corpo da função main().
- Inclua o arquivo de cabeçalho do algoritmo para usar suas funções.
- Inclua o arquivo de cabeçalho iostream para usar suas funções.
- Inclua o arquivo de cabeçalho da lista para usar suas funções.
- Chame a função main(). A lógica do programa deve ser adicionada no corpo desta função.
- Crie uma lista chamada my_list com um conjunto de 4 inteiros.
- Insira o elemento 11 na frente da lista chamada my_list.
- Insira o elemento 18 no final da lista chamada my_list.
- Crie um iterador e use-o para encontrar o elemento 10 da lista my_list.
- Use uma instrução if para determinar se o elemento acima foi encontrado ou não.
- Insira o elemento 21 antes do elemento acima se for encontrado.
- Fim do corpo da instrução if.
- Use um loop for para criar uma variável de loop x. Esta variável será usada para iterar sobre os elementos da lista.
- Imprima os valores da lista no console.
- Fim do corpo do for um loop.
- Fim do corpo da função main().
- Para excluir um único item, basta passar uma posição inteira. O item será excluído.
- Para excluir um intervalo, você passa os iteradores inicial e final. Vamos demonstrar isso.
- Inclua o arquivo de cabeçalho do algoritmo para usar suas funções.
- Inclua o arquivo de cabeçalho iostream para usar suas funções.
- Inclua o arquivo de cabeçalho da lista para usar suas funções.
- Inclua o namespace std em nosso programa para usar suas classes sem chamá-lo.
- Chame a função main(). A lógica do programa deve ser adicionada no corpo desta função.
- Crie uma lista chamada my_list com um conjunto de 4 inteiros.
- Imprima algum texto no console.
- Use um loop for para criar uma variável de loop x. Esta variável será usada para iterar sobre os elementos da lista.
- Imprima os valores da lista no console.
- Fim do corpo do loop for.
- Crie um iterador i que aponte para o primeiro elemento da lista.
- Use a função erase() apontada pelo iterador i.
- Imprima algum texto no console.
- Use um loop for para criar uma variável de loop x. Esta variável será usada para iterar sobre os elementos da lista.
- Imprima os valores da lista no console. Isso vem após a exclusão.
- Fim do corpo do loop for.
- O programa deve retornar um valor após a conclusão bem-sucedida.
- Fim do corpo da função main().
- O std::list é um contêiner de armazenamento.
- Permite a inserção e exclusão de itens de qualquer lugar em tempo constante.
- É implementado como um link duplo
- Os dados std::list podem ser acessados bidirecionalmente e sequencialmente.
- std::list não suporta acesso aleatório rápido. No entanto, ele suporta acesso sequencial de todas as direções.
- Você pode espalhar elementos de lista de std::list em diferentes blocos de memória.
- Você pode reduzir ou expandir std::list de ambas as extremidades conforme necessário durante o tempo de execução.
- Para inserir itens em std::list, usamos a função insert().
- Para excluir itens do std::list, usamos a função erase().
template < class Type, class Alloc =allocator<T> > class list;
Aqui está uma descrição dos parâmetros acima:
Exemplos 1:
#include <algorithm> #include <iostream> #include <list> int main() { std::list<int> my_list = { 12, 5, 10, 9 }; for (int x : my_list) { std::cout << x << '\n'; } }
Saída:
Aqui está uma captura de tela do código:
Explicação do código:
Funções de lista C++
Aqui estão as funções comuns std::list:
Função Descrição insert()Esta função insere um novo item antes da posição que o iterador aponta.push_back()Esta função adiciona um novo item no final da lista.push_front()Adiciona um novo item na frente da lista.pop_front()Apaga o item da lista first item.size()Esta função determina o número de elementos da lista.front()To determina os primeiros itens da lista.back()To determina o último item da lista.reverse()Inverte os itens da lista.merge()Mescla dois listas ordenadas.
Construtores
Aqui está a lista de funções fornecidas pelo arquivo de cabeçalho
- :
Exemplo 2:
#include <iostream> #include <list> using namespace std; int main(void) { list<int> l; list<int> l1 = { 10, 20, 30 }; list<int> l2(l1.begin(), l1.end()); list<int> l3(move(l1)); cout << "Size of list l: " << l.size() << endl; cout << "List l2 contents: " << endl; for (auto it = l2.begin(); it != l2.end(); ++it) cout << *it << endl; cout << "List l3 contents: " << endl; for (auto it = l3.begin(); it != l3.end(); ++it) cout << *it << endl; return 0; }
Saída:
Aqui está uma captura de tela do código:
Explicação do código:
Propriedades do contêiner
Aqui está a lista de propriedades do contêiner:
Propriedade Descrição Os contêineres SequenceSequence ordenam seus elementos em uma sequência linear estrita. Os elementos são acessados por sua posição na seqüência.Lista duplamente ligadaCada elemento tem informações sobre como localizar os elementos anteriores e seguintes. Isso permite tempo constante para operações de inserção e exclusão.Allocator-awareUm objeto alocador é usado para modificar o tamanho do armazenamento dinamicamente.
Inserindo em uma lista
Existem diferentes funções que podemos usar para inserir valores em uma lista. Vamos demonstrar isso:
Exemplo 3:
#include <algorithm> #include <iostream> #include <list> int main() { std::list<int> my_list = { 12, 5, 10, 9 }; my_list.push_front(11); my_list.push_back(18); auto it = std::find(my_list.begin(), my_list.end(), 10); if (it != my_list.end()) { my_list.insert(it, 21); } for (int x : my_list) { std::cout << x << '\n'; } }
Saída:
Aqui está uma captura de tela do código:
Explicação do código:
Exclusão de uma lista
É possível excluir itens de uma lista. A função erase() permite excluir um item ou um intervalo de itens de uma lista.
Exemplo 4:
#include <algorithm> #include <iostream> #include <list> using namespace std; int main() { std::list<int> my_list = { 12, 5, 10, 9 }; cout << "List elements before deletion: "; for (int x : my_list) { std::cout << x << '\n'; } list<int>::iterator i = my_list.begin(); my_list.erase(i); cout << "\nList elements after deletion: "; for (int x : my_list) { std::cout << x << '\n'; } return 0; }
Saída:
Aqui está a captura de tela do código:
Explicação do código:
Resumo:
Linguagem C
- Operadores em C++ com Exemplo:O que é, Tipos e Programas
- C++ do… while loop com exemplos
- Instrução C++ Switch Case com EXEMPLO
- Alocação dinâmica de matrizes em C++ com exemplo
- Ponteiros C++ com exemplos
- Sobrecarga do operador C++ com exemplos
- Estrutura C++ com exemplo
- Funções C++ com exemplos de programas
- Diferença entre estrutura e classe:explicada com exemplo de C++
- Contador Python em coleções com exemplo