Descripción
Solucionar uno mismo los problemas derivados del análisis de las colecciones de datos por medio del diseño de algoritmos es esencial para evolucionar como programador, así como saber implementar dichas soluciones utilizando el lenguaje de programación Python.
Si quiere aprender nuevas formas de representar datos, su manejo y su uso en la solución de problemas, este libro le proporcionará todo lo que necesita. En él se mantiene la premisa de que enseñar a programar debe ir más allá de explicar un lenguaje de programación, debe desarrollar la capacidad de análisis, despertar el interés por diseñar soluciones eficaces y eficientes, promover la escritura de código agradable de leer y, por lo tanto, fácil de mantener y evolucionar, y debe convencer acerca de la importancia de probar todos los algoritmos, para asegurarse de que funcionan correctamente.
Este manual se organiza en cuatro capítulos: el primero está dedicado a las listas; el segundo, a los conjuntos; el tercero, a los diccionarios, y el cuarto, a los arreglos. Cada tema se desarrolla poniendo especial énfasis en el concepto, dado que lo importante es entender la teoría para luego poder llevarla a la práctica y usarla en el diseño de algoritmos con éxito. Además, todos los programas escritos en Python, presentados como ejemplos o como solución a los problemas, pueden consultarse en un repositorio de GitHub.
Sin duda, este es un libro imprescindible para todos aquellos que tengan conocimientos básicos de algorítmica y quieran profundizar en esta área. También se ajusta muy bien a materias de ciencias de la computación dedicadas a la enseñanza del desarrollo de algoritmos y su implementación usando lenguajes de programación, por lo que es el manual ideal para las primeras materias de cualquier plan de estudios que incluya este campo del saber.
Si antes de profundizar en este libro quiere asentar las bases del pensamiento algorítmico e introducirse en algunos de los elementos básicos del lenguaje, le recomendamos el libro Aprende a programar en Python: de cero al infinito.
Índice
Acerca de la autora ...................................... V
Agradecimientos .......................................... VII
Prefacio .......................................................... XI
Capítulo 1
Listas
1.1 Introducción ........................................... 1
1.2 Operaciones ........................................... 4
1.3. Listas anidadas ..................................... 47
1.4 Listas por comprensión ......................... 51
1.5 Otras funciones incorporadas: filter, map y zip ........................................................ 60
1.6 Problemas de práctica ......................... 73
Capítulo 2
Conjuntos
2.1 Introducción ............................................ 75
2.2 Operaciones de inserción y eliminación ..................................................... 78
2.3 Operaciones entre conjuntos ............... 80
2.4 El tipo de dato frozenset ...................... 93
Capítulo 3
Diccionarios
3.1 Introducción ............................................117
3.2 Operaciones ...........................................120
3.3 Diccionarios y algo más ........................140
3.4 Diccionarios por comprensión..............148
3.5 Paso de parámetros y diccionarios ....150
3.6 Diccionarios y conjuntos ......................156
3.7 Diccionarios y la función enumerate ..157
3.8 Diccionarios en la solución de problemas .....................................................158
Capítulo 4
Arreglos
4.1 Introducción ........................................... 171
4.2 Construcción de arreglos ..................... 172
4.3 Operaciones en arreglos ....................... 175
4.4 Más operaciones con arreglos ............ 193
4.5 Arreglos y archivos ................................ 195
4.6 Implementación de operaciones con arreglos .................................................. 199
4.6.1 Búsqueda ............................................ 199
4.6.2 Inserción .............................................. 206
4.6.3 Eliminación ......................................... 209
4.6.4 Ordenación ......................................... 213
4.7 Solución de problemas usando arreglos ........................................................... 217
4.8 Arreglos de 2 dimensiones .................. 247
4.8.1 Creación de arreglos bidimensionales y asignación de valores ................................ 249
4.8.2 Acceso a los elementos de los arreglos bidimensionales ........................................... 253
4.9 Solución de problemas usando arreglos bidimensionales ........................................... 254
4.10 Arreglos de n dimensiones................. 292
Índice temático .......................................... 293