Mapa en la biblioteca de plantillas estándar (STL) de C++ con ejemplo de impresión
¿Qué es std::map?
En C++, un MAPA es un contenedor asociativo que almacena elementos en forma de mapa. Cada elemento del mapa se compone de clave-valor y un valor asignado. Dos valores asignados no pueden compartir los mismos valores clave.
Los valores clave son buenos para clasificar e identificar elementos de forma única. Los valores asignados son para almacenar contenido asociado con la clave. Los dos pueden diferir en tipos, pero el tipo de miembro los combina a través de un tipo de par que combina ambos.
En este tutorial de C++, aprenderá:
- ¿Qué es std::map?
- ¿Por qué usar std::map?
- Sintaxis:
- Tipos de miembros:
- Funciones integradas
- Iterando sobre elementos del mapa
- Insertar datos en std::map
- Buscar en un mapa
- Eliminación de datos de un mapa
¿Por qué usar std::map?
Estas son las razones para usar el mapa:
- std::el mapa almacena claves únicas solo en orden según los criterios de clasificación elegidos.
- Es fácil y rápido buscar elementos usando la clave.
- Solo se adjunta un elemento a cada clave.
- std::map se puede usar como una matriz asociativa.
- std::map se puede implementar usando árboles binarios (equilibrados).
Sintaxis:
Para declarar std::map, use esta sintaxis:
std::map<key_datatype, value_datatype>map_name;
- key_datatype indica el tipo de datos de las claves del mapa.
- Value_datatype indica el tipo de datos de los valores correspondientes a las claves del mapa.
- map_name es el nombre del mapa.
Por ejemplo:
map<string, int> my_map;
Declaramos un mapa llamado my_map. El mapa tendrá una cadena como clave tipos de datos y enteros como valores tipo de datos.
Tipos de miembros:
Las funciones miembro pueden usar los siguientes tipos de miembros como parámetros o como tipo de retorno:
- tipo_clave: Clave (El primer parámetro en la plantilla)
- tipo_asignado: T (El segundo parámetro en la plantilla)
- comparación_clave: Comparar (El tercer parámetro en la plantilla)
- tipo_de_asignación: Alloc (El cuarto parámetro en la plantilla)
- tipo_valor: par
- valor_comparado: Clase de función anidada para comparar elementos
- referencia: allocator_type::referencia
- const_reference: allocator_type::const_reference
- puntero: allocator_type::puntero
- const_pointer: allocator_type::const_pointer
- iterador: un iterador bidireccional para value_type
- const_iterador: un iterador bidireccional a la const value_type
- iterador_inverso: un iterador inverso
- const_reverse_iterator: un iterador inverso constante
- diferencia_tipo: ptrdiff_t
- tipo_tamaño: tamaño_t
Funciones integradas
std::map viene con funciones incorporadas. Algunos de estos incluyen:
- comenzar()- Esta función devuelve el iterador al primer elemento del mapa.
- tamaño()- Esta función devuelve el número de elementos en un mapa.
- vacío()- Esta función devuelve un valor booleano que indica si un mapa está vacío.
- insertar(par(clave, valor))- Esta función inserta un nuevo par clave-valor en un mapa.
- buscar(val)- Esta función da el iterador al elemento val si se encuentra. De lo contrario, devolverá m.end().
- Borrar (posición del iterador)- Esta función elimina el elemento en la posición señalada por el iterador.
- borrar(const g) – Esta función elimina el valor-clave g de un mapa.
- Borrar ()- Esta función elimina todos los elementos de un mapa.
Iterando sobre elementos del mapa
Puede iterar sobre los elementos del mapa. Simplemente necesitamos crear un iterador y usarlo para esto.
Por ejemplo:
Ejemplo 1:
#include <iostream> #include <string> #include <map> using namespace std; int main() { map<int, string> Students; Students.insert(std::pair<int, string>(200, "Alice")); Students.insert(std::pair<int, string>(201, "John")); cout << "Map size is: " << Students.size() << endl; cout << endl << "Default map Order is: " << endl; for (map<int, string>::iterator it = Students.begin(); it != Students.end(); ++it) { cout << (*it).first << ": " << (*it).second << endl; } }
Salida:
Aquí hay una captura de pantalla del código:
Explicación del código:
- Incluya el archivo de encabezado iostream en nuestro código para usar sus funciones.
- Incluya el archivo de encabezado de cadena en nuestro código para usar sus funciones.
- Incluya el archivo de encabezado del mapa en nuestro código para usar sus funciones.
- Incluya el espacio de nombres estándar en nuestro código para usar sus clases sin llamarlo.
- Llama a la función main(). El { marca el comienzo del cuerpo de la función.
- Cree un mapa llamado Estudiantes donde las claves serán números enteros y los valores serán cadenas.
- Insertar valores en el mapa Estudiantes. Se insertará una clave de 200 y un valor de Alice en el mapa.
- Insertar valores en el mapa Estudiantes. Se insertará una clave de 201 y un valor de John en el mapa.
- Use la función size() para obtener el tamaño del mapa llamado Students. Esto debería devolver un 2.
- Imprime algo de texto en la consola.
- Utilice un bucle for para crear un iterador denominado iterar sobre los elementos del mapa denominado Estudiantes.
- Imprima los valores del mapa Estudiantes en la consola.
- Fin del cuerpo del ciclo for.
- Fin del cuerpo de la función main().
Insertar datos en std::map
Puede ingresar elementos en std::map usando la función insert(). Recuerda que las claves std::map deben ser únicas.
Entonces, primero verifica si cada clave está presente en el mapa. Si está presente, la entrada no se insertará, pero devuelve el iterador de la entrada existente. Si no está presente, se inserta la entrada.
La función tiene las siguientes variaciones:
- insertar(par)- con esta variación, se inserta un par clave-valor en el mapa.
- insertar(start_itr, end_itr)- con esta variación, las entradas se insertarán dentro del rango definido por start_itr y end_itr desde otro mapa.
El insertar_o_asignar() funciona de la misma manera que la función insert(), pero si la clave dada ya existe en el mapa, su valor será modificado.
Ejemplo 2:
#include <map> #include <iostream> using namespace std; int main() { map<int, int> m{ {1,3} , {2,4} , {3,5} }; m.insert({ 5, 6 }); m.insert({ 1, 8 }); m.insert_or_assign(1, 6); cout << "Key\tElement\n"; for (auto itr = m.begin(); itr != m.end(); ++itr) { cout << itr->first << '\t' << itr->second << '\n'; } return 0; }
Salida:
Aquí hay una captura de pantalla del código:
Explicación del código:
- Incluya el archivo de encabezado del mapa en nuestro código para usar sus funciones.
- Incluya el archivo de encabezado iostream en nuestro código para usar sus funciones.
- Incluya el espacio de nombres estándar en nuestro código para usar sus clases sin llamarlo.
- Llama a la función main(). El { marca el comienzo del cuerpo de la función.
- Cree un mapa llamado m donde las claves serán números enteros y los valores serán números enteros. Se han realizado tres entradas en el mapa.
- Insertar una nueva entrada en el mapa m. Se insertará una clave de 5 y un valor de 6 en el mapa.
- Intentando hacer una entrada en una clave ya existente. Dado que la clave 1 ya existe en el mapa, no se realizará la entrada.
- Utilizar la función insert_or_assign() para insertar o modificar una entrada existente. Dado que la clave 1 ya existe, su valor se cambiará a 6.
- Imprime algo de texto en la consola. El carácter "\t" crea un espacio horizontal mientras que el carácter "\n" mueve el cursor del mouse a la siguiente línea.
- Use un bucle for para crear un iterador llamado itr para iterar sobre los elementos del mapa llamado m.
- Imprime los valores del mapa m en la consola. El carácter “\t” crea un espacio horizontal entre cada tecla y su valor correspondiente. Por el contrario, el carácter "\n" mueve el cursor del mouse a la siguiente línea después de cada iteración.
- Fin del cuerpo del bucle for a.
- El programa debe devolver valor al completarse con éxito.
- Fin del cuerpo de la función main().
Buscar en un mapa
Podemos usar la función find() para buscar elementos en un mapa por sus claves. Si no se encuentra la clave, la función devuelve std::map::end. De lo contrario, se devolverá un iterador del elemento buscado.
Ejemplo 2:
#include <iostream> #include <string> #include <map> using namespace std; int main() { map<int, string> Students; Students.insert(std::pair<int, string>(200, "Alice")); Students.insert(std::pair<int, string>(201, "John")); std::map<int, string>::iterator it = Students.find(201); if (it != Students.end()) { std::cout << endl << "Key 201 has the value: => "<< Students.find(201)->second << '\n'; } }
Salida:
Aquí hay una captura de pantalla del código:
Explicación del código:
- Incluya el archivo de encabezado iostream en nuestro código para usar sus funciones sin obtener errores.
- Incluya el archivo de encabezado de cadena en nuestro código para usar sus funciones sin obtener errores.
- Incluya el archivo de encabezado del mapa en nuestro código para usar sus funciones sin obtener errores.
- Incluya el espacio de nombres estándar en nuestro código para usar sus clases sin llamarlo.
- Llama a la función main(). El { marca el comienzo del cuerpo de la función main().
- Cree un mapa llamado Estudiantes cuyas claves serán números enteros y cadenas de valores.
- Insertar valores en el mapa Estudiantes. Se insertará una clave de 200 y un valor de Alice en el mapa.
- Insertar valores en el mapa Estudiantes. Se insertará una clave de 201 y un valor de John en el mapa.
- Busque el valor asociado con una clave de 201.
- Utilice una instrucción if para comprobar si se encuentra el valor de la clave.
- Imprima el valor de la clave junto con algún texto en la consola.
- Fin del cuerpo de la instrucción if.
- Fin del cuerpo de la función main().
Eliminación de datos de un mapa
Podemos usar la función erase() para eliminar un valor de un mapa. Simplemente creamos un iterador que apunta al elemento a eliminar. Luego, el iterador se pasa a la función erase().
Ejemplo 3:
#include <iostream> #include <string> #include <map> using namespace std; int main() { map<std::string, int> my_map; my_map.insert(std::make_pair("cow", 1)); my_map.insert(std::make_pair("cat", 2)); my_map["lion"] = 3; map<std::string, int>::iterator it = my_map.find("cat"); my_map.erase(it); for (map<string, int>::iterator it = my_map.begin(); it != my_map.end(); ++it) cout << (*it).first << ": " << (*it).second << endl; return 0; }
Salida:
Aquí hay una captura de pantalla del código:
Explicación del código:
- Incluya el archivo de encabezado iostream en nuestro código para usar sus funciones.
- Incluya el archivo de encabezado de cadena en nuestro código para usar sus funciones.
- Incluya el archivo de encabezado del mapa en nuestro código para usar sus funciones.
- Incluya el espacio de nombres estándar en nuestro código para usar sus clases sin llamarlo.
- Llama a la función main(). El { marca el comienzo del cuerpo de la función main().
- Cree un mapa llamado my_map cuyas claves serán cadenas y valores enteros.
- Insertar valores en el mapa my_map. Se insertará una clave de Vaca y un valor de 1 en el mapa.
- Insertar valores en el mapa my_map. Se insertará una clave de Cat y un valor de 2 en el mapa.
- Agregue un valor 3 en el mapa my_map con una clave de león.
- Cree un iterador para iterar sobre el mapa my_map buscando el gato clave.
- Eliminar el elemento señalado por el iterador.
- Use un iterador para iterar sobre los elementos del mapa my_map desde el principio hasta el final.
- Imprima el contenido del mapa my_map en la consola.
- El programa debe devolver la salida al completarse con éxito.
- Fin del cuerpo de la función main().
Resumen:
- Un mapa es un contenedor asociativo que almacena elementos en forma de mapa.
- Cada elemento del mapa tiene un valor clave y un valor asignado.
- En un mapa, dos valores asignados no pueden compartir valores clave.
- Los valores clave ayudan a clasificar e identificar elementos de forma única.
- Los valores asignados ayudan a almacenar contenido asociado con la clave.
- El mapa de C++ almacena claves únicas en orden ordenado.
- Para trabajar con el mapa de C++, creamos un iterador para iterar sobre los elementos.
- Con el iterador, podemos realizar tareas como buscar y eliminar elementos del mapa.
Lenguaje C
- Funciones de biblioteca estándar de C
- Operadores en C++ con Ejemplo:Qué es, Tipos y Programas
- C++ do...while bucle con ejemplos
- Declaración de caso de cambio de C ++ con EJEMPLO
- C++ Asignación dinámica de arreglos con ejemplo
- Punteros de C++ con ejemplos
- Sobrecarga de operadores de C++ con ejemplos
- Estructura C++ con ejemplo
- std::list en C++ con ejemplo
- Funciones de C++ con ejemplos de programas
- Diferencia entre estructura y clase:explicada con el ejemplo de C++