Método eficiente de armazenamento utilizando containers (Vector e Map)
Publicado por Robson Lopes (última atualização em 20/12/2009)
[ Hits: 7.929 ]
Para quem deseja um exemplo de containers sendo utilizado com uma classe própria, esse será um bom exemplo.
/*
* Nome: Robson Lopes
* Nick: Rob_Som
* Linguagem: C++
* Titulo: Método eficiente de Armazenamento, utilizando containers(Vector, Map, string).
* Objetivo: Cadastrar pessoas em ordem alfabética com eficiencia O(log(n))
*/
#include <iostream>
#include <vector>
#include <map>
#include <string>
using std::map;
using std::vector;
using std::string;
using std::cin;
using std::cout;
using std::endl;
class Pessoa{
private:
/*Atributos*/
string Nome;
string Sobrenome;
int Idade;
public:
Pessoa(string , string , int ); //Construtor
/*Funções membros*/
void setNome(string n){ this->Nome = n; }
void setSobrenome(string s){ this->Sobrenome = s; }
void setIdade(int i){ this->Idade = i > 0 ? i : 1; } //validação
string getNome() const { return this->Nome; }
string getSobrenome() const { return this->Sobrenome; }
int getIdade() const { return this->Idade; }
void PrintPessoa() const;
};
Pessoa::Pessoa(string n, string s, int i){
this->setNome(n);
this->setSobrenome(s);
this->setIdade(i);
}
void Pessoa::PrintPessoa() const {
cout << "Nome: " << this->getNome() << endl;
cout << "Sobrenome: " << this->getSobrenome() << endl;
cout << "Idade: " << this->getIdade() << endl;
}
int main(void){
/*Na Chave utilizo container string. Para o Valor utilizo o container vector armazenando um
* objeto do tipo Pessoa. */
map< string, vector<Pessoa> > Mymap;
/*Iterator para correr o container map. Lembrando que será ordenado pela chave(nome completo).
* Fique tranquilo, que o map se encarregará disso. */
map< string, vector<Pessoa> >::iterator itM;
/*Iterator para acessar o container Vector que possui o Objeto Pessoa */
vector<Pessoa>::iterator itV;
int opcao, idade;
string nome, sobrenome, completo, chave;
do{
cout << "1. Para Adicionar" << endl;
cout << "2. Para Lista" << endl;
cout << "3. Para Sair" << endl;
cout << "Opção: ";
cin >> opcao;
if(opcao == 1){
cout << endl << "Digite o Nome: ";
cin >> nome;
cout << "Digite o Sobrenome: ";
cin >> sobrenome;
cout << "Digite a Idade: ";
cin >> idade;
completo = nome + sobrenome;
Pessoa *A = new Pessoa(nome, sobrenome, idade);
Mymap[completo].push_back(*A);
}
else if(opcao == 2){
cout << endl;
for(itM = Mymap.begin(); itM != Mymap.end(); itM++){
/*(*itM).first eu pego a chave e begin() é a primeira posicão do Vector */
itV = Mymap[(*itM).first].begin();
itV->PrintPessoa();
cout << endl;
}
}
}while(opcao != 3);
return 0;
}
Um parser para tratar opções passadas para um programa em C
Métodos de Ordenação - Quick Sort
Como extrair chaves TOTP 2FA a partir de QRCODE (Google Authenticator)
Linux em 2025: Segurança prática para o usuário
Desktop Linux em alta: novos apps, distros e privacidade marcam o sábado
IA chega ao desktop e impulsiona produtividade no mundo Linux
Novos apps de produtividade, avanços em IA e distros em ebulição agitam o universo Linux
Como instalar o repositório do DBeaver no Ubuntu
Como instalar o Plex Media Server no Ubuntu
Digitando underscore com "shift" + "barra de espaços"
Como ativar a lixeira e recuperar aquivos deletados em um servidor Linux
Como mudar o nome de dispositivos Bluetooth via linha de comando
O programa assinador digital (1)
PIP3 - erro ao instalar módulo do mariadb para o Python (9)
É normal não gostar de KDE? (8)
dpkg: erro: gatilho de arquivo duplicado chamado pelo arquivo de nome (6)









