PCAP - Programming Essentials in Python 1 - Modulo 03
PCAP - Programming Essentials in Python 1 - Modulo 03
Valores booleanos.
Instrucciones if-elif-else.
Bucles while y for.
Control de flujo.
Operaciones lógicas y bit a bit.
Listas y arreglos.
Preguntas y respuestas
Si, es cierto.
No, esto es falso.
Ejercicios
2 == 2 Revisar
True (verdadero) - por supuesto, 2 es igual a 2. Python
responderá True (Recuerda este par de literales predefinidos, True y False -
También son palabras clave de Python).
2 == 2. Revisar
Esta pregunta no es tan fácil como la primera. Por suerte, Python es capaz de
convertir el valor entero en su equivalente real, y en consecuencia, la respuesta
es True
1 == 2 Revisar
Esto debería ser fácil. La respuesta será (o mejor dicho, siempre es) False .
var == 0
Ten en cuenta que no podemos encontrar la respuesta si no sabemos qué valor está
almacenado actualmente en la variable (var) .
Ahora imagina a un programador que sufre de insomnio, y tiene que contar las ovejas
negras y blancas por separado siempre y cuando haya exactamente el doble de ovejas
negras que de las blancas.
ovejasNegras == 2 * ovejasBlancas
Debido a la baja prioridad de el operador == ,la pregunta será tratada como la siguiente:
ovejasNegras == (2 * ovejaBlancas)
print(var == 0)
print(var == 0)
print(var != 0)
print(var != 0)
Si deseas saber si hay más ovejas negras que blancas, puedes escribirlo de la
siguiente manera:
ovejasNegras > ovejasBlancas # mayor que.
El operador mayor que tiene otra variante especial, una variante no estricta,
pero se denota de manera diferente que la notación aritmética
clásica: >= (mayor o igual que).
Ambos operadores (estrictos y no estrictos), así como los otros dos que se
analizan en la siguiente sección, son operadores binarios con enlace en el
lado izquierdo, y su prioridad es mayor que la mostrada por == y != .
Si queremos saber si tenemos que usar un gorro o no, nos hacemos la siguiente
pregunta:
Prioridad Operador
1 +, - unario
2 **
3 *, /, %
4 +, - binario
6 == , !=
LABORATORIO
Tiempo Estimado
5 minutos
Nivel de dificultad
Muy Fácil
Objetivos
Familiarizarse con la función input() .
Familiarizarse con los operadores de comparación en Python.
Escenario
Usando uno de los operadores de comparación en Python, escribe un programa simple de
dos líneas que tome el parámetro n como entrada, que es un entero, e
imprime False si n es menor que 100 , y True si n es mayor o igual que 100 .
No debes crear ningún bloque if (hablaremos de ellos muy pronto). Prueba tu código
usando los datos que te proporcionamos.
Datos de prueba
Ejemplo de entrada: 55
Ejemplo de entrada: 99
Ejemplo de entrada: -5
Para tomar tales decisiones, Python ofrece una instrucción especial. Debido a su
naturaleza y su aplicación, se denomina instrucción condicional (o
declaración condicional).
if cierto_o_no:
hacer_esto_si_cierto
La palabra clave if .
Uno o más espacios en blanco.
Una expresión (una pregunta o una respuesta) cuyo valor se interpretar
únicamente en términos de True (cuando su valor no sea cero)
y False (cuando sea igual a cero).
Unos dos puntos seguido de una nueva línea.
Una instrucción con sangría o un conjunto de instrucciones (se requiere
absolutamente al menos una instrucción); la sangría se puede lograr de
dos maneras: insertando un número particular de espacios (la
recomendación es usar cuatro espacios de sangría), o usando
el tabulador; nota: si hay mas de una instrucción en la parte con sangría,
la sangría debe ser la misma en todas las líneas; aunque puede parecer
lo mismo si se mezclan tabuladores con espacios, es importante que
todas las sangrías sean exactamente iguales Python 3 no permite
mezclar espacios y tabuladores para la sangría.
después, almorzaremos
if ClimaEsBueno:
irAcaminar()
almorzar()
Como puedes ver, tender la cama, tomar una ducha y dormir y soñar se
ejecutan condicionalmente, cuando contadorOvejas alcanza el límite
deseado.
Nota: no hay una palabra sobre lo que suceder· si el clima es malo. Solo
sabemos que no saldremos al aire libre, pero no sabemos que podríamos hacer.
Es posible que también queramos planificar algo en caso de mal tiempo.
Python nos permite expresar dichos planes alternativos. Esto se hace con una
segunda forma, ligeramente mas compleja, de la declaración condicional, la
declaración if-else :
if condición_true_or_false:
ejecuta_si_condición_true
else:
ejecuta_si_condición_false
Por lo tanto, hay una nueva palabra: else - esta es una palabra reservada.
La parte del código que comienza con else dice que hacer si no se cumple la
condición especificada por el if (observa los dos puntos después de la
palabra).
if climaEsBueno:
irACaminar()
else:
irAlCine()
almorzar()
Todo lo que hemos dicho sobre la sangría funciona de la misma manera dentro
de la rama else :
if climaEsBueno:
irACaminar()
Diviertirse()
else:
irAlCine()
disfrutaLaPelicula()
almorzar()
Lee lo que hemos planeado para este domingo. Si hay buen clima, saldremos a
caminar. Si encontramos un buen restaurante, almorzaremos allí. De lo
contrario, vamos a comer un sandwich. Si hay mal clima, iremos al cine. Si no
hay boletos, iremos de compras al centro comercial más cercano.
if encontramosBuenRestaurante:
almorzar()
else:
comerSandwich()
else:
if hayBoletosDisponibles:
irAlCine()
else:
irDeCompras()
elif se usa para verificar más de una condición, y para detener cuando se
encuentra la primera declaración verdadera.
if climaBueno:
iraCaminar()
elif hayBoletosDisponibles:
IralCine()
elif mesasLibres:
almorzar()
else:
jugarAjedrezEnCasa()
Esto puede sonar un poco desconcertante, pero ojalá que algunos ejemplos
simples ayuden a comprenderlo mejor.
Ejemplo 1:
Comenzaremos con el caso más simple: ¿Cómo identificar el mayor de los dos
números? :
nmasGrande = numero1
else:
nmasGrande = numero2
#imprimir el resultado
El fragmento de código anterior debe estar claro: lee dos valores enteros, los compara y
encuentra cuál es el más grande.
Ejemplo 2:
Ahora vamos a mostrarte un hecho intrigante. Python tiene una característica interesante,
mira el código a continuación:
#imprimir el resultado
Nota: si alguna de las ramas de if-elif-else contiene una sola instrucción, puedes codificarla
de forma más completa (no es necesario que aparezca una línea con sangría después de
la palabra clave), pero solo continúa la línea después de los dos puntos).
Sin embargo, este estilo puede ser engañoso, y no lo vamos a usar en nuestros programas
futuros, pero definitivamente vale la pena saber si quieres leer y entender los programas
de otra persona.
Es hora de complicar el código: encontremos el mayor de los tres números. ¿Se ampliará
el código? Un poco.
Suponemos que el primer valor es el más grande. Luego verificamos esta hipótesis con los
dos valores restantes.
nmasGrande = numero1
nmasGrande = numero2
nmasGrande = numero3
#imprimir el resultado
Este método es significativamente más simple que tratar de encontrar el número más
grande comparando todos los pares de números posibles (es decir, el primero con el
segundo, el segundo con el tercero y el tercero con el primero). Intenta reconstruir el
código por ti mismo.
línea 04 print(numeroMayor)
línea 05 exit()
Hacemos un trato con el usuario: cuando se ingresa el valor -1 , será una señal
de que no hay más datos y que el programa debe finalizar su trabajo.
Las líneas 02 a 08 forman un bucle. Los pasaremos tantas veces como sea
necesario para revisar todos los valores ingresados.
Información Adicional
Python a menudo viene con muchas funciones integradas que harán el trabajo
por ti. Por ejemplo, para encontrar el número más grande de todos, puede usar
una función incorporada de Python llamada max() . Puedes usarlo con múltiples
argumentos. Analiza el código de abajo:
numeroMayor = max(numero1,numero2,numero3)
# imprimir el resultado
Vamos a hablar sobre estas (y muchas otras) funciones pronto. Por el momento,
nuestro enfoque se centrará en la ejecución condicional y los bucles para
permitirte ganar más confianza en la programación y enseñarte las habilidades
que te permitirán comprender y aplicar los dos conceptos en tu codigo.
Entonces, por ahora, no estamos tomando atajos.
LABORATORIO
Tiempo estimado
5-10 minutos
Nivel de dificultad
Fácil
Objetivos
Familiarizarse con la función input().
Familiarizarse con los operadores de comparación en Python.
Familiarizarse con el concepto de ejecución condicional.
Escenario
Espatifilo, más comúnmente conocida como la planta de Cuna de Moisés o flor de la paz,
es una de las plantas para interiores más populares que filtra las toxinas dañinas del aire.
Algunas de las toxinas que neutraliza incluyen benceno, formaldehído y amoníaco.
Imagina que tu programa de computadora ama estas plantas. Cada vez que recibe una
entrada en forma de la palabra Espatifilo , grita involuntariamente a la consola la
siguiente cadena: "¡Espatifilo es la mejor planta de todas!"
Escribe un programa que utilice el concepto de ejecución condicional, tome una cadena
como entrada y que:
Prueba tu código con los datos que te proporcionamos. ¡Y hazte de un Espatifilo también!
Datos de prueba
Entrada de muestra: espatifilo
Tiempo estimado
10-15 minutos
Nivel de dificultad
Fácil/Medio
Objetivos
Familiarizar al estudiante con:
Si el ingreso del ciudadano no era superior a 85,528 pesos, el impuesto era igual al
18% del ingreso menos 556 pesos y 2 centavos (esta fue la llamada exención
fiscal ).
Si el ingreso era superior a esta cantidad, el impuesto era igual a 14,839 pesos y 2
centavos, más el 32% del excedente sobre 85,528 pesos.
Nota: Este país feliz nunca devuelve dinero a sus ciudadanos. Si el impuesto calculado es
menor que cero, solo significa que no hay impuesto (el impuesto es igual a cero). Ten esto
en cuenta durante tus cálculos.
Observa el código en el editor: solo lee un valor de entrada y genera un resultado, por lo
que debes completarlo con algunos cálculos inteligentes.
Datos de prueba
Entrada de muestra: 10000
Resultado esperado: El impuesto es: 1244.0 pesos
LABORATORIO
Tiempo estimado
10-15 minutos
Nivel de dificultad
Fácil/Medio
Objetivos
Familiarizar al estudiante con:
Desde la introducción del calendario gregoriano (en 1582), se utiliza la siguiente regla para
determinar el tipo de año:
Observa el código en el editor: solo lee un número de año y debe completarse con las
instrucciones que implementan la prueba que acabamos de describir.
El código debe mostrar uno de los dos mensajes posibles, que son Año bisiesto o Año
común , según el valor ingresado.
Sería bueno verificar si el año ingresado cae en la era gregoriana y emitir una advertencia
de lo contrario: No dentro del período del calendario gregoriano . Consejo:
utiliza los operadores != y % .
Datos de prueba
Entrada de muestra: 2000
Puntos clave
1. Los operadores de comparación (o también denominados relacionales) se
utilizan para comparar valores. La siguiente tabla ilustra cómo funcionan los
operadores de comparación, asumiendo que x=0 , y=1 y z=0 :
x = 10
if x == 10: # condición
print("x es igual a 10") # ejecutado si la condición es
verdadera
x = 10
x = 10
else:
print ("x es mayor o igual a 10") # ejecutado si la
condición es False
x = 10
if x > 5: # Verdadero
print("x > 5")
if x > 8: # Verdadero
print("x > 8")
else:
print("Se ejecutará el else")
x = 10
if x == 10: # Verdadero
print("x == 10")
else:
print("No se ejecutará el else")
x = 10
if x > 5: # Verdadero
if x == 6: # Falso
print("anidado: x == 6")
elif x == 10: # Verdadero
print("anidado: x == 10")
else:
print("anidado: else")
else:
print("else")
Ejercicio 1
x = 5
y = 10
z = 8
print(x > y)
print(y > z)
Revisar
False
True
Ejercicio 2
¿Cuál es la salida del siguiente fragmento de código?
x, y, z = 5, 10, 8
print(x > z)
print((y - 5) == x)
Revisar
False
True
Ejercicio 3
x, y, z = 5, 10, 8
x, y, z = z, y, x
print(x > z)
print((y - 5) == x)
Revisar
True
False
Ejercicio 4
x = 10
if x == 10:
print(x == 10)
if x > 5:
print(x > 5)
if x < 10:
else:
print("else")
Revisar
Ejercicio 5
x = "1"
if x == 1:
print("uno")
elif x == "1":
if int (x)> 1:
print("dos")
print("tres")
else:
print("cuatro")
if int (x) == 1:
print("cinco")
else:
print("seis")
Revisar
cuatro
cinco
Ejercicio 6
¿Cuál es la salida del siguiente fragmento de código?
x = 1
y = 1.0
z = "1"
if x == y:
print("uno")
if y == int (z):
print("dos")
elif x == y:
print("tres")
else:
print("cuatro")
Revisar
uno
dos
Ten en cuenta que este registro también declara que, si no hay nada que hacer,
nada ocurrirá.
while expresión_condicional:
instrucción
while expresión_condicional:
instrucción_uno
instruccion_dos
instrucción_tres
instrucción_n
while True:
numeroMayor = numero
numerosImpares = 0
numerosPares = 0
# 0 termina la ejecución
while numero != 0:
if numero % 2 == 1:
numerosImpares += 1
else:
numerosPares += 1
# imprimir resultados
Intenta recordar cómo Python interpreta la verdad de una condición y ten en cuenta que
estas dos formas son equivalentes:
if numero % 2 == 1: e if numero % 2:
contador = 5
while contador != 0:
contador -= 1
Este código está destinado a imprimir la cadena "Dentro del ciclo" y el valor
almacenado en la variable contador durante un ciclo dado exactamente cinco veces. Una
vez que la condición se haya cumplido (la variable contador ha alcanzado 0 ), se sale del
ciclo y aparece el mensaje "Fuera del ciclo". así como el valor almacenado
en contador se imprime.
Pero hay una cosa que se puede escribir de forma más compacta: la condición del
ciclo while .
contador=5
while contador:
contador - = 1
RECUERDA
No te sientas obligado a codificar tus programas de una manera que siempre sea la más
corta y la más compacta. La legibilidad puede ser un factor más importante. Manten tu
código listo para un nuevo programador.
LABORATORIO
Tiempo estimado
15 minutos
Nivel de dificultad
Fácil
Objetivos
Familiarizar al estudiante con:
Tu tarea es ayudar al mago a completar el código en el editor de tal manera que el código:
INFO EXTRA
Por cierto, mira la función print() . La forma en que lo hemos utilizado aquí se
llama impresión multilínea . Puede utilizar comillas triples para imprimir cadenas en
varias líneas para facilitar la lectura del texto o crear un diseño especial basado en texto.
Experimenta con ello.
i = 0
while i < 100:
# hacer_algo()
i += 1
Sería bueno si alguien pudiera hacer esta cuenta aburrida por ti. ¿Es eso
posible?
Por supuesto que lo es, hay un ciclo especial para este tipo de tareas, y se
llama for .
for i in range(10):
print("El valor de i es actualmente", i)
Nota:
El valor de i es actualmente 2
El valor de i es actualmente 5
¿Sabes por qué? El primer argumento pasado a la función range() nos dice cual es el
número de inicio de la secuencia (por lo tanto, 2 en la salida). El segundo argumento le
dice a la función dónde detener la secuencia (la función genera números hasta el número
indicado por el segundo argumento, pero no lo incluye). Finalmente, el tercer argumento
indica el paso, que en realidad significa la diferencia entre cada número en la secuencia
de números generados por la función.
2 (número inicial) → 5 ( 2 incremento por 3 es igual a 5 - el número está dentro del rango
de 2 a 8) → 8 ( 5 incremento por 3 es igual a 8 - el número no está dentro del rango de 2 a
8, porque el parámetro de parada no está incluido en la secuencia de números generados
por la función).
Nota: si el conjunto generado por la función range() está vacío, el ciclo no ejecutará su
cuerpo en absoluto.
Echemos un vistazo a un programa corto cuya tarea es escribir algunas de las primeras
potencias de dos:
pow = 1
pow * = 2
La variable exp se utiliza como una variable de control para el ciclo e indica el valor actual
del exponente. La propia exponenciación se sustituye multiplicando por dos. Dado que
2 0 es igual a 1, después 2 × 1 es igual a 21, 2 × 21 es igual a 22, y así sucesivamente.
¿Cuál es el máximo exponente para el cual nuestro programa aún imprime el resultado?
LABORATORIO
Tiempo estimado
5 minutos
Nivel de dificultad
Muy fácil
Objetivos
Familiarizar al estudiante con:
La palabra Mississippi también se usa para un propósito ligeramente diferente: para contar
mississippily (mississippimente).
Si no estás familiarizado con la frase, estamos aquí para explicarte lo que significa: se
utiliza para contar segundos.
La idea detrás de esto es que agregar la palabra Mississippi a un número al contar los
segundos en voz alta hace que suene más cercano al reloj, y por lo tanto "un Mississippi,
dos Mississippi, tres Mississippi" tomará aproximadamente unos tres segundos reales de
tiempo. A menudo lo usan los niños que juegan al escondite para asegurarse de que el
buscador haga un conteo honesto.
Tu tarea es muy simple aquí: escribe un programa que use un ciclo for para "contar de
forma mississippi" hasta cinco. Habiendo contado hasta cinco, el programa debería
imprimir en la pantalla el mensaje final "¡Listo o no, ahí voy!"
INFO EXTRA
Ten en cuenta que el código en el editor contiene dos elementos que pueden no ser del
todo claros en este momento: la declaración import time y el método sleep() . Vamos
a hablar de ellos pronto.
Por el momento, nos gustaría que supieras que hemos importado el módulo time y hemos
utilizado el método sleep() para suspender la ejecución de cada función posterior
de print() dentro del ciclo for durante un segundo, de modo que el mensaje enviado a
la consola se parezca a un conteo real. No te preocupes, pronto aprenderás más sobre
módulos y métodos.
Salida esperada
1 Mississippi
2 Mississippi
3 Mississippi
4 Mississippi
5 Mississippi
Ahora te mostraremos dos ejemplos simples para ilustrar como funcionan las dos
instrucciones. Mira el código en el editor. Ejecuta el programa y analiza la salida. Modifica
el código y experimenta.
numeroMayor = -99999999
contador = 0
while True:
if numero == -1:
break
contador = 1
numeroMayor = numero
if contador != 0:
else:
numeroMayor = -99999999
contador = 0
if numero == -1:
continue
contador = 1
numeroMayor = numero
if contador:
else:
print("No ha ingresado ningún número")
LABORATORIO
Tiempo estimado
10 minutos
Nivel de dificultad
Fácil
Objetivos
Familiarizar al estudiante con:
Diseña un programa que use un ciclo while y le pida continuamente al usuario que
ingrese una palabra a menos que ingrese "chupacabra" como la palabra de salida
secreta, en cuyo caso el mensaje "¡Has dejado el ciclo con éxito". Debe
imprimirse en la pantalla y el ciclo debe terminar.
LABORATORIO
Tiempo estimado
10-15 minutos
Nivel de dificultad
Fácil
Objetivos
Familiarizar al estudiante con:
Un ciclo for .
El concepto de ejecución condicional (if-elif-else).
La declaración continue .
Tu programa debe:
Datos de prueba
Entrada de muestra: Gregory
Salida esperada:
Y
Entrada de muestra: abstemious
Salida esperada:
Salida esperada:
LABORATORIO
Tiempo estimado
5-10 minutos
Nivel de dificultad
Fácil
Objetivos
Familiarizar al estudiante con:
Un ciclo for .
El concepto de ejecución condicional (if-elif-else ).
La declaración continue .
Tu programa debe:
Datos de prueba
Entrada de muestra: Gregory
Salida esperada:
GRGRY
Salida esperada:
BSTMS
Salida esperada:
Echa un vistazo al fragmento en el editor. Hay algo extraño al final: la palabra clave else .
Como pudiste haber sospechado, los ciclos también pueden tener la rama else , como
los if .
La rama else del ciclo siempre se ejecuta una vez, independientemente de si el ciclo
ha entrado o no en su cuerpo .
i = 5
while i < 5:
print(i)
i += 1
else:
print("else:", i)
i = 111
print(i)
else:
print("else:", i)
Cuando el cuerpo del ciclo no se ejecuta, la variable de control conserva el valor que tenía
antes del ciclo.
Ahora vamos a informarte sobre otros tipos de variables. Nuestras variables actuales solo
pueden almacenar un valor a la vez, pero hay variables que pueden hacer mucho más;
pueden almacenar tantos valores como desees.
LABORATORIO
Tiempo estimado
20-30 minutos
Nivel de dificultad
Medio
Objetivos
Familiarizar al estudiante con:
Nota: La altura se mide por el número de capas completas: si los constructores no tienen
la cantidad suficiente de bloques y no pueden completar la siguiente capa, terminan su
trabajo inmediatamente.
Datos de prueba
Entrada de muestra: 6
Entrada de muestra: 20
Entrada de muestra: 2
Tiempo estimado
20 minutos
Nivel de dificultad
Media
Objetivos
Familiarizar al estudiante con:
1. Toma cualquier número entero que no sea negativo y que no sea cero y asígnale el
nombre c0 .
2. Si es par, evalúa un nuevo c0 como c0 ÷ 2 .
3. De lo contrario, si es impar, evalúe un nuevo c0 como 3 × c0 + 1 .
4. Si c0 ≠ 1 , salta al punto 2.
La hipótesis dice que, independientemente del valor inicial de c0 , el valor siempre tiende a
1.
Por supuesto, es una tarea extremadamente compleja usar una computadora para probar
la hipótesis de cualquier número natural (incluso puede requerir inteligencia artificial), pero
puede usar Python para verificar algunos números individuales. Tal vez incluso encuentres
el que refutaría la hipótesis.
Escribe un programa que lea un número natural y ejecute los pasos anteriores siempre
que c0 sea diferente de 1. También queremos que cuente los pasos necesarios para
lograr el objetivo. Tu código también debe mostrar todos los valores intermedios de c0 .
Sugerencia: la parte más importante del problema es como transformar la idea de Collatz
en un ciclo while - esta es la clave del éxito.
Datos de prueba
Entrada de muestra: 15
Salida esperada:
46
23
70
35
106
53
160
80
40
20
10
16
pasos = 17
Entrada de muestra: 16
Salida esperada:
pasos = 4
3070
1535
4606
2303
6910
3455
10366
5183
15550
7775
23326
11663
34990
17495
52486
26243
78730
39365
118096
59048
29524
14762
7381
22144
11072
5536
2768
1384
692
346
173
520
260
130
65
196
98
49
148
74
37
112
56
28
14
22
11
34
17
52
26
13
40
20
10
16
2
1
pasos = 62
Puntos clave
# Ejemplo 1
while True:
print("Atascado en un ciclo infinito")
# Ejemplo 2
contador = 5
while contador > 2:
print(contador)
contador -= 1
# Ejemplo 1
palabra = "Python"
for letter in palabra:
print(letter, fin = "*")
# Ejemplo 2
for i in range(1, 10):
if i % 2 == 0:
print(i)
text = "pyxpyxpyx"
for letter in text:
if letter == "x":
continue
print(letter, end= "")
3. Los ciclos while y for también pueden tener una cláusula else en Python.
La cláusula else se ejecuta después de que el ciclo finalice su ejecución
siempre y cuando no haya terminado con break , por ejemplo:
n = 0
while n != 3:
print(n)
n += 1
else:
print(n, "else")
print()
Código de ejemplo:
for i in range(3):
print(i, end=" ") # salidas: 0 1 2
# línea de código
# línea de código
Revisar
Solución de muestra:
for i in range(0, 11):
if i % 2 != 0:
print(i))
Ejercicio 2
x = 1
# line of code
# line of code
# line of code
Revisar
Solución de muestra:
x = 1
if x % 2 != 0:
print(x)
x += 1
Ejercicio 3
Crea un programa con un bucle for y una declaración break . El programa debe
iterar sobre los caracteres en una dirección de correo electrónico, salir del bucle
cuando llegue al símbolo @ e imprimir la parte antes de @ en una línea. Usa el
esqueleto de abajo:
for ch in "[email protected]":
if ch == "@":
# línea de código
# línea de código
Revisar
Solución de muestra:
for ch in "[email protected]":
if ch == "@":
break
print(ch, end="")
Ejercicio 4
if digit == "0":
# línea de código
# línea de código
# línea de código
Revisar
Solución de muestra:
for digit in "0165031806510":
if digit == "0":
print("x", end="")
continue
print(digit, end="")
Ejercicio 5
n = 3
while n > 0:
print(n + 1)
n -= 1
else:
print(n)
Revisar
Ejercicio 6
n = range(4)
for num in n:
print(num - 1)
else:
print(num)
Revisar
-1
Ejercicio 7
print(i)
Revisar
Lógica de computadora
¿Te has dado cuenta de que las condiciones que hemos usado hasta ahora han
sido muy simples, por no decir, bastante primitivas? Las condiciones que
utilizamos en la vida real son mucho más complejas. Veamos esta oración:
Hemos utilizado la conjunción and (y) , lo que significa que salir a caminar
depende del cumplimiento simultáneo de estas dos condiciones. En el lenguaje
de la lógica, tal conexión de condiciones se denomina conjunción. Y ahora otro
ejemplo:
and
Un operador de conjunción lógica en Python es la palabra y. Es un operador
binario con una prioridad inferior a la expresada por los operadores de
comparación. Nos permite codificar condiciones complejas sin el uso de
paréntesis como este:
Argumento A Argumento B A y B
or
Un operador de disyunción es la palabra or . Es un operador binario con una
prioridad más baja que and (al igual que + en comparación con * ). Su tabla
de verdad es la siguiente:
Argumento A Argumento B A or B
False True
True False
Expresiones lógicas
Creemos una variable llamada var y asignémosle 1 . Las siguientes condiciones
son equivalentes a pares:
print(var > 0)
Observa como se han utilizado los paréntesis para codificar las expresiones: las
colocamos allí para mejorar la legibilidad.
Deberíamos agregar que ninguno de estos operadores de dos argumentos se
puede usar en la forma abreviada conocida como op= . Vale la pena recordar
esta excepción.
i = 1
j = not not i
Operadores bitwise
Sin embargo, hay cuatro operadores que le permiten manipular bits de datos
individuales. Se denominan operadores bitwise.
0 0 0 0
1 0 1 1
0 0 1 1
1 1 1 0
0 1
1 0
Los operadores bitwise son más estrictos: tratan con cada bit por separado.
Si asumimos que la variable entera ocupa 64 bits (lo que es común en los
sistemas informáticos modernos), puede imaginar la operación a nivel de bits
como una evaluación de 64 veces del operador lógico para cada par de bits de
los argumentos. Su analogía es obviamente imperfecta, ya que en el mundo
real todas estas 64 operaciones se realizan al mismo tiempo
(simultáneamente).
i = 15
j = 22
Si asumimos que los enteros se almacenan con 32 bits, la imagen a nivel de bits
de las dos variables será la siguiente:
i: 00000000000000000000000000001111
j: 00000000000000000000000000010110
Se ejecuta la asignación:
og = i and j
Estamos tratando con una conjunción lógica aquí. Vamos a trazar el curso de los
cálculos. Ambas variables i y j no son ceros, por lo que se considerará que
representan a True . Al consultar la tabla de verdad para el operador and ,
podemos ver que el resultado será True . No se realizan otras operaciones.
log: True
bit = i & j
El operador & operará con cada par de bits correspondientes por separado,
produciendo los valores de los bits relevantes del resultado. Por lo tanto, el
resultado será el siguiente:
i 000000000000000000000000000 01111
j 000000000000000000000000000 10110
logneg = not i
bitneg = ~i
i 0000000000000000000000000000 1111
bitneg = ~i 1111111111111111111111111111 0000
x = x & y x &= y
x = x | y x |= y
x = x ^ y x ^= y
flagRegister = 0x1234
flagRegister = 000000000000000000000000000000x000
x & 1 = x
x & 0 = 0
00000000000000000000000000001000
(observa el 1 en la posición de tu bit) como resultado, obtendrás una de las
siguientes cadenas de bits:
Dicha secuencia de ceros y unos, cuya tarea es tomar el valor o cambiar los bits
seleccionados, se denomina máscara de bits.
Construyamos una máscara de bits para detectar el estado de tus bits. Debería
apuntar a el tercer bit. Ese bit tiene el peso de 23=8 . Se podría crear una
máscara adecuada mediante la siguiente declaración:
theMask = 8
2. Reinicia tu bit: asigna un cero al bit, mientras que todos los otros bits
deben permanecer sin cambios; usemos la misma propiedad de la conjunción
que antes, pero usemos una máscara ligeramente diferente, exactamente como
se muestra a continuación:
11111111111111111111111111110111
3. Establece tu bit : asigna un 1 a tu bit, mientras que todos los bits restantes
deben permanecer sin cambios; usa la siguiente propiedad de disyunción:
x | 1 = 1
x | 0 = x
Ya estás listo para configurar su bit con una de las siguientes instrucciones:
x ^ 1 = ~x
x ^ 0 = x
flagRegister ^= theMask
12345 × 10 = 123450
Como puede ver, multiplicar por diez es de hecho un desplazamiento de todos los
dígitos a la izquierda y llenar el vacío resultante con cero.
12340 ÷ 10 = 1234
La computadora realiza el mismo tipo de operación, pero con una diferencia: como dos es
la base para los números binarios (no 10), desplazar un valor un bit a la izquierda
corresponde a multiplicarlo por dos ; respectivamente, desplazar un bit a la derecha
es como dividir entre dos (observe que se pierde el bit más a la derecha).
Los operadores de cambio en Python son un par de dígrafos: < < y > > , sugiriendo
claramente en qué dirección actuará el cambio.
17 68 8
Nota:
Y aquí está la tabla de prioridades actualizada , que contiene todos los operadores
presentados hasta ahora:
Prioridad Operador
1 ! ~ (tipo) ++ -- + - unario
2 **
3 * / %
4 + - binario
5 << >>
6 <<=>> =
7 == !=
8 &
9 |
10 &&
11 ||
12 = += -= *= /= %= &= ^= |= >>= <<=
Puntos clave
1. Python es compatible con los siguientes operadores lógicos:
2. Puedes utilizar operadores bit a bit para manipular bits de datos individuales.
Los siguientes datos de muestra:
& hace un bit a bit and (y), por ejemplo, x & y = 0 , el cual es 0000
0000 en binario.
| hace un bit a bit or (o), por ejemplo, x | y = 31 , el cual es 0001
1111 en binario.
˜ hace un bit a bit not (no), por ejemplo, ˜ x = 240 , el cual es 1111
0000 en binario.
^ hace un bit a bit xor, por ejemplo, x ^ y = 31 , el cual es 0001 1111 en
binario.
>> hace un desplazamiento bit a bit a la derecha, por ejemplo, y >> 1 =
8 , el cual es 0000 1000 en binario.
<< hace un desplazamiento bit a bit a la izquierda, por ejemplo, y << 3 =
, el cual es 1000 0000 en binario.
Ejercicio 1
x = 1
y = 0
False
Ejercicio 2
¿Cuál es la salida del siguiente fragmento de código?
x = 4
y = 1
a = x & y
b = x | y
c = ~ x
d = x ^ 5
e = x >> 2
f = x << 2
print(a, b, c, d, e, f)
Revisar
0 5 -5 1 1 16
var1 = int(input())
var2 = int(input())
var3 = int(input())
var4 = int(input())
var5 = int(input())
var6 = int(input())
:
:
Si no crees que esta sea una tarea complicada, toma un papel y escribe un
programa que:
Hasta ahora, has aprendido como declarar variables que pueden almacenar
exactamente un valor dado a la vez. Tales variables a veces se
denominan escalares por analogía con las matemáticas. Todas las variables
que has usado hasta ahora son realmente escalares.
Piensa en lo conveniente que sería declarar una variable que podría almacenar
más de un valor . Por ejemplo, cien, o mil o incluso diez mil. Todavía sería una
y la misma variable, pero muy amplia y espaciosa. ¿Suena atractivo? Quizás,
pero ¿cómo manejarías un contenedor así lleno de valores diferentes? ¿Cómo
elegirías solo el que necesitas?
numeros = [ 10, 5, 7, 2, 1]
Los elementos dentro de una lista pueden tener diferentes tipos . Algunos
de ellos pueden ser enteros, otros son flotantes y otros pueden ser listas.
Python ha adoptado una convención que indica que los elementos de una lista
están siempre numerados desde cero. Esto significa que el elemento
almacenado al principio de la lista tendrá el número cero. Como hay cinco
elementos en nuestra lista, al último de ellos se le asigna el número cuatro. No
olvides esto.
Listas de indexación
¿Cómo cambias el valor de un elemento elegido en la lista?
numeros[0] = 111
Y ahora queremos copiar el valor del quinto elemento al segundo elemento. ¿Puedes
adivinar como hacerlo?
numeros = [10, 5, 7, 2, 1]
numeros[0] = 111
El valor dentro de los corchetes que selecciona un elemento de la lista se llama un índice,
mientras que la operación de seleccionar un elemento de la lista se conoce
como indexación.
Vamos a utilizar la función print() para imprimir el contenido de la lista cada vez que
realicemos los cambios. Esto nos ayudará a seguir cada paso con más cuidado y ver que
sucede después de una modificación de la lista en particular.
Nota: todos los índices utilizados hasta ahora son literales. Sus valores se fijan en el
tiempo de ejecución, pero cualquier expresión también puede ser un índice. Esto abre
muchas posibilidades.
Suponiendo que todas las operaciones anteriores se hayan completado con éxito, el
fragmento enviará 111 a la consola.
Como puedes ver en el editor, la lista también puede imprimirse como un todo, como aquí:
Como probablemente hayas notado antes, Python decora la salida de una manera que
sugiere que todos los valores presentados forman una lista. La salida del fragmento de
ejemplo anterior se ve así:
[111, 1, 7, 2, 1]
La función len()
La longitud de una lista puede variar durante la ejecución. Se pueden agregar nuevos
elementos a la lista, mientras que otros pueden eliminarse de ella. Esto significa que la
lista es una entidad muy dinámica.
Observa la última línea de código en el editor, ejecuta el programa y verifica que valor
imprimirá en la consola. ¿Puedes adivinar?
Tienes que apuntar al elemento que quieres eliminar, desaparecerá de la lista y la longitud
de la lista se reducirá en uno.
Mira el fragmento de abajo. ¿Puedes adivinar qué salida producirá? Ejecuta el programa
en el editor y comprueba.
del numeros[1]
print(len(numeros))
print(numeros)
No puedes acceder a un elemento que no existe , no puedes obtener su valor ni
asignarle un valor. Ambas instrucciones causarán ahora errores de tiempo de ejecución:
print(numeros[4])
numeros[4] = 1
Nota: hemos eliminado uno de los elementos de la lista; ahora solo hay cuatro elementos
en la lista. Esto significa que el elemento número cuatro no existe.
print(numeros[-1])
Del mismo modo, el elemento con un índice igual a -2 es el anterior al último en la lista.
print(numeros[-2])
El último elemento accesible en nuestra lista es numeros[-4] (el primero). ¡No intentes ir
más lejos!
LABORATORIO
Tiempo estimado
5 minutos
Nivel de dificultad
Muy fácil
Objetivos
Familiarizar al estudiante con:
Tu tarea es:
Escribir una línea de código que solicite al usuario que reemplace el número
central en la lista con un número entero ingresado por el usuario (paso 1).
Escribir una línea de código que elimine el último elemento de la lista (paso 2).
Escribir una línea de código que imprima la longitud de la lista existente (paso 3).
Una función no pertenece a ningún dato: obtiene datos, puede crear nuevos
datos y (generalmente) produce un resultado.
Un método hace todas estas cosas, pero también puede cambiar el estado de
una entidad seleccionada.
resultado = funcion(argumento)
resultado = data.method(arg)
Nota: el nombre del método está precedido por el nombre de los datos que
posee el método. A continuación, se agrega un punto, seguido del nombre del
método y un par de paréntesis que encierran los argumentos.
El método se comportará como una función, pero puede hacer algo más:
puede cambiar el estado interno de los datos a partir de los cuales se ha
invocado.
lista.append(valor)
lista.insert(ubicación,valor)
El primero muestra la ubicación requerida del elemento a insertar. Nota: todos los
elementos existentes que ocupan ubicaciones a la derecha del nuevo elemento
(incluido el que está en la posición indicada) se desplazan a la derecha, para hacer
espacio para el nuevo elemento.
El segundo es el elemento a insertar.
numeros.insert(1,333)
for i in range(5):
miLista.insert(0, i + 1)
print(miLista)
¿Qué pasará ahora? Ejecuta el programa y comprueba si esta vez también tenías razón.
Deberías obtener la misma secuencia, pero en orden inverso (este es el mérito de usar el
método insert() ).
miLista = [10, 1, 8, 3, 5]
suma = 0
for i in miLista:
suma += i
print(suma)
Imagina que necesitas reorganizar los elementos de una lista, es decir, revertir el orden de
los elementos: el primero y el quinto, así como el segundo y cuarto elementos serán
intercambiados. El tercero permanecerá intacto.
variable1 = 1
variable2 = 2
variable2 = variable1
variable1 = variable2
variable1 = 1
variable2 = 2
auxiliar = variable1
variable1 = variable2
variable2 = auxiliar
Python ofrece una forma más conveniente de hacer el intercambio, echa un vistazo:
variable1 = 1
variable2 = 2
Listas en acción
Ahora puedes intercambiar fácilmente los elementos de la lista para revertir su orden:
miLista = [10, 1, 8, 3, 5]
print(miLista)
[5, 3, 8, 1, 10]
¿Seguirá siendo aceptable con una lista que contenga 100 elementos? No, no lo hará.
miLista = [10, 1, 8, 3, 5]
longitud = len(miLista)
print(miLista)
Nota:
Hemos asignado la variable longitud a la longitud de la lista actual (esto hace
que nuestro código sea un poco más claro y más corto).
Hemos lanzado el ciclo for para que se ejecute a través de su
cuerpo longitud // 2 veces (esto funciona bien para listas con longitudes pares
e impares, porque cuando la lista contiene un número impar de elementos, el del
medio permanece intacto).
Hemos intercambiado el elemento i (desde el principio de la lista) por el que tiene
un índice igual a (longitud-i-1) (desde el final de la lista); en nuestro ejemplo,
for i igual a 0 la (longitud-i-1) da 4 ; for i igual a 3 , da 3 : esto es
exactamente lo que necesitábamos.
LABORATORIO
Tiempo estimado
10-15 minutos
Nivel de dificultad
Fácil
Objetivos
Familiarizar al estudiante con:
La banda sufrió muchos cambios de formación, que culminaron en 1962 con la formación
de John Lennon, Paul McCartney, George Harrison y Richard Starkey (mejor conocido
como Ringo Starr).
Escribe un programa que refleje estos cambios y le permita practicar con el concepto de
listas. Tu tarea es:
Puntos clave
print (miLista) # salida: [1, '?', True, 'Soy una cadena', 256, 0]
miLista.append ("last")
3. Las listas pueden estar anidadas, por ejemplo: miLista = [1, 'a',
["lista", 64, [0, 1], False]] .
miLista = [1, 2, 3, 4]
del miLista[2]
5.Las listas pueden ser iteradas mediante el uso del bucle for , por ejemplo:
print(color)
print(len(miLista)) # la salidas es 5
del miLista[2]
Ejercicio 1
lst = [1, 2, 3, 4, 5]
lst.insert(1, 6)
del lst[0]
lst.append(1)
print(lst)
Revisar
[6, 2, 3, 4, 5, 1]
Ejercicio 2
lst = [1, 2, 3, 4, 5]
lst2 = []
agregar = 0
agregar += number
lst2.append (agregar)
print(lst2)
Revisar
Ejercicio 3
lst = []
del lst
print(lst)
Revisar
Ejercicio 4
print(lst[1])
print(len(lst))
Revisar
[2, 3]
3
Ordenamiento Burbuja
Ahora que puedes hacer malabarismos con los elementos de las listas, es hora
de aprender como ordenarlos. Se han inventado muchos algoritmos de
clasificación, que difieren mucho en velocidad, así como en complejidad. Vamos
a mostrar un algoritmo muy simple, fácil de entender, pero
desafortunadamente, tampoco es muy eficiente. Se usa muy raramente, y
ciertamente no para listas extensas.
8 10 6 2 4
8 6 10 2 4
Vamos más allá y observemos los elementos tercero y cuarto. Una vez más,
esto no es lo que se supone que es. Tenemos que intercambiarlos:
8 6 2 10 4
Ahora comprobemos los elementos cuarto y quinto. Si, ellos también están en
las posiciones equivocadas. Ocurre otro intercambio:
8 6 2 4 10
El primer paso a través de la lista ya está terminado. Todavía estamos lejos de
terminar nuestro trabajo, pero algo curioso ha sucedido mientras tanto. El
elemento más grande, 10 , ya ha llegado al final de la lista. Ten en cuenta que
este es el lugar deseado para el. Todos los elementos restantes forman un lío
pintoresco, pero este ya está en su lugar.
10
4
2
6
8
6 8 2 4 10
6 2 8 4 10
6 2 4 8 10
2 6 4 8 10
Ahora 6 necesita ir a su lugar. Cambiamos el segundo y el tercer elemento:
2 4 6 8 10
while swapped:
swapped = False # no hay swaps hasta ahora
print(miLista)
Python, sin embargo, tiene sus propios mecanismos de clasificación. Nadie necesita
escribir sus propias clases, ya que hay un número suficiente de herramientas listas para
usar.
miLista.sort()
print(miLista)
[2, 4, 6, 8, 10]
Como puedes ver, todas las listas tienen un método denominado sort() , que las ordena
lo más rápido posible. Ya has aprendido acerca de algunos de los métodos de lista
anteriormente, y pronto aprenderás más sobre otros.
Puntos clave
1. Puedes usar el método sort() para ordenar los elementos de una lista, por
ejemplo:
lst = [5, 3, 1, 2, 4]
print(lst)
lst.sort ()
2.También hay un método de lista llamado reverse() , que puedes usar para
invertir la lista, por ejemplo:
lst = [5, 3, 1, 2, 4]
print(lst)
lst.reverse()
Ejercicio 1
lst.sort ()
print(lst)
Revisar
Ejercicio 2
¿Cuál es la salida del siguiente fragmento de código?
a = 3
b = 1
c = 2
lst = [a, c, b]
lst.sort ()
print(lst)
Revisar
[1, 2, 3]
Ejercicio 3
a = "A"
b = "B"
c = "C"
d = ""
lst = [a, b, c, d]
lst.reverse ()
print(lst)
Revisar
El programa:
Lee estas dos líneas una vez más, la diferencia es esencial para comprender de que
vamos a hablar a continuación.
Rodajas Poderosas
Afortunadamente, la solución está al alcance de su mano: su nombre es rodaja.
Una rodaja es un elemento de la sintaxis de Python que permite hacer una copia nueva
de una lista, o partes de una lista.
lista1 = [1]
lista2 = lista1[:]
lista1[0] = 2
print(lista2)
Su salida es [1] .
Esta parte no visible del código descrito como [:] puede producir una lista
completamente nueva.
miLista[inicio:fin]
Como puedes ver, se asemeja a la indexación, pero los dos puntos en el interior hacen una
gran diferencia.
Una rodaja de este tipo crea una nueva lista (de destino), tomando elementos de la
lista de origen: los elementos de los índices desde el principio hasta el fin-1 .
Nota: no hasta el fin , sino hasta fin-1 . Un elemento con un índice igual a fin es el
primer elemento el cual no participa en la segmentación.
Es posible utilizar valores negativos tanto para el inicio como para el fin(al igual que en la
indexación).
miLista = [10, 8, 6, 4, 2]
print(nuevaLista)
La lista nuevaLista contendrá inicio-fin (3-1=2) elementos, los que tienen índices
iguales a 1 y 2 (pero no 3 )
miLista[inicio:fin]
Para repetir:
inicio es el índice del primer elemento incluido en la rodaja.
fin es el índice del primer elemento no incluido en la rodaja.
miLista = [10, 8, 6, 4, 2]
nuevaLista = miLista [1:-1]
print(nuevaLista)
miLista = [10, 8, 6, 4, 2]
nuevaLista = miLista [-1:1]
print(nuevaLista)
Rodajas: continuación
Si omites inicio en tu rodaja, se supone que deseas obtener un segmento que comienza
en el elemento con índice 0 .
miLista[:fin]
miLista[0:fin]
miLista = [10, 8, 6, 4, 2]
print(nuevaLista)
Es por esto que su salida es: [10, 8, 6] .
Del mismo modo, si omites el fin en tu rodaja, se supone que deseas que el segmento
termine en el elemento con el índice len(miLista) .
miLista[inicio:]
miLista[inicio:len(miLista)]
miLista = [10, 8, 6, 4, 2]
nuevaLista = miLista[3:]
print(nuevaLista)
Rodajas: continuación
Como hemos dicho antes, el omitir inicio y fin hace una copia de toda la lista:
miLista = [10, 8, 6, 4, 2]
print(nuevLista)
miLista = [10, 8, 6, 4, 2]
del miLista[1:3]
print(miLista)
miLista = [10, 8, 6, 4, 2]
del miLista[:]
print(miLista)
Echa un vistazo:
miLista = [10, 8, 6, 4, 2]
del miLista
print(miLista)
elem in miLista
El primero de ellos intenta encontrar el mayor valor en la lista. Mira el código en el editor.
El código puede ser reescrito para hacer uso de la forma recién introducida del ciclo for :
for i in miLista:
if i > mayor:
mayor = i
print(mayor)
if i > mayor:
mayor = i
print(mayor)
La pregunta es: ¿Cuál de estas dos acciones consume más recursos informáticos: solo
una comparación o partir casi todos los elementos de una lista?
for i in range(len(miLista)):
Encontrado = miLista[i] == Encontrar
if Encontrado:
break
if Encontrado:
print("Elemento encontrado en el índice", i)
else:
print("ausente")
Nota:
Nota:
LABORATORIO
Tiempo estimado
10-15 minutos
Nivel de dificultad
Fácil
Objetivos
Familiarizar al estudiante con:
Indexación de listas.
Utilizar operadores in y not in .
Escenario
Imagina una lista: no muy larga ni muy complicada, solo una lista simple que contiene
algunos números enteros. Algunos de estos números pueden estar repetidos, y esta es la
clave. No queremos ninguna repetición. Queremos que sean eliminados.
Tu tarea es escribir un programa que elimine todas las repeticiones de números de la lista.
El objetivo es tener una lista en la que todos los números aparezcan no más de una vez.
Nota: Asume que la lista original está ya dentro del código, no tienes que ingresarla desde
el teclado. Por supuesto, puedes mejorar el código y agregar una parte que pueda llevar a
cabo una conversación con el usuario y obtener todos los datos.
Sugerencia: Te recomendamos que crees una nueva lista como área de trabajo temporal,
no necesitas actualizar la lista actual.
No hemos proporcionado datos de prueba, ya que sería demasiado fácil. Puedes usar
nuestro esqueleto en su lugar.
Puntos clave
1. Si tienes una lista l1 , la siguiente asignación: l2 = l1 no hace una copia de
la lista l1 , pero hace que las variables l1 y l2 apunten a la misma lista en
la memoria . Por ejemplo:
vehiculosDos = vehiculosUno
2. Si deseas copiar una lista o parte de la lista, puede hacerlo haciendo uso
de rodajas(slicing):
3. También puede utilizar índices negativos para hacer uso de rodajas. Por
ejemplo:
nuevaLista = listaMuestra[2:-1]
miLista = [1, 2, 3, 4, 5]
miLista = [1, 2, 3, 4, 5]
del miLista[:]
Ejercicio 1
l2 = l1
l3 = l2
del l1[0]
del l2[0]
print(l3)
Revisar
['C']
Ejercicio 2
l2 = l1
l3 = l2
del l1[0]
del l2
print(l3)
Revisar
['B', 'C']
Ejercicio 3
l2 = l1
l3 = l2
del l1[0]
del l2[:]
print(l3)
Revisar
[]
Ejercicio 4
l2 = l1[:]
l3 = l2[:]
del l1[0]
del l2[0]
print(l3)
Revisar
Ejercicio 5
Un tablero de ajedrez está compuesto de filas y columnas. Hay ocho filas y ocho
columnas. Cada columna está marcada con las letras de la A a la H. Cada línea está
marcada con un número del uno al ocho.
La ubicación de cada campo se identifica por pares de letras y dígitos. Por lo tanto,
sabemos que la esquina inferior derecha del tablero (la que tiene la torre blanca) es A1,
mientras que la esquina opuesta es H8.
Supongamos que podemos usar los números seleccionados para representar cualquier
pieza de ajedrez. También podemos asumir que cada fila en el tablero de ajedrez es una
lista.
fila = []
for i in range(8):
row.append(PEON_BLANCO)
Crea una lista que contiene ocho elementos que representan la segunda fila del tablero de
ajedrez: la que está llena de peones (supon que PEON_BLANCO es un símbolo
predefinido que representa un peón blanco).
El mismo efecto se puede lograr mediante una comprensión de lista, la sintaxis especial
utilizada por Python para completar o llenar listas masivas.
Una comprensión de lista es en realidad una lista, pero se creó sobre la marcha durante
la ejecución del programa, y no se describe de forma estática.
Ejemplo # 1:
El fragmento de código genera una lista de diez elementos y rellena con cuadrados de diez
números enteros que comienzan desde cero (0, 1, 4, 9, 16, 25, 36, 49, 64, 81)
Ejemplo # 2:
El fragmento crea un arreglo de ocho elementos que contiene las primeras ocho potencias
del numero dos (1, 2, 4, 8, 16, 32, 64, 128)
Ejemplo # 3:
El fragmento hace una lista con solo los elementos impares de la lista cuadrados .
Entonces, si queremos crear una lista de listas que representan todo el tablero de ajedrez,
se puede hacer de la siguiente manera:
tablero = []
for i in range(8):
fila = [EMPTY for i in range(8)]
tablero.append(fila)
Nota:
La parte interior del bucle crea una fila que consta de ocho elementos(cada uno de
ellos es igual a EMPTY ) y lo agrega a la lista del tablero .
La parte exterior se repite ocho veces.
En total, la lista tablero consta de 64 elementos (todos iguales a EMPTY ).
Este modelo imita perfectamente el tablero de ajedrez real, que en realidad es una lista de
elementos de ocho elementos, todos ellos en filas individuales. Resumamos nuestras
observaciones:
Los elementos de las filas son campos, ocho de ellos por fila.
Los elementos del tablero de ajedrez son filas, ocho de ellos por tablero de
ajedrez.
Como las listas de comprensión puede ser anidadas, podemos acortar la creación del
tablero de la siguiente manera:
La parte interna crea una fila, y la parte externa crea una lista de filas.
Echa un vistazo al tablero de ajedrez. Cada campo contiene un par de índices que se
deben dar para acceder al contenido del campo:
Echando un vistazo a la figura que se muestra arriba, coloquemos algunas piezas de
ajedrez en el tablero. Primero, agreguemos todas las torres:
tablero[0][0] = TORRE
tablero[0][7] = TORRE
tablero[7][0] = TORRE
tablero[7][7] = TORRE
tablero[4][2] = CABALLO
Imagina que desarrollas una pieza de software para una estación meteorológica
automática. El dispositivo registra la temperatura del aire cada hora y lo hace durante todo
el mes. Esto te da un total de 24 × 31 = 744 valores. Intentemos diseñar una lista capaz de
almacenar todos estos resultados.
Primero, debes decidir qué tipo de datos sería adecuado para esta aplicación. En este
caso, sería mejor un float , ya que este termómetro puede medir la temperatura con una
precisión de 0.1 ℃.
Luego tomarás la decisión arbitraria de que las filas registrarán las lecturas cada hora
exactamente (por lo que la fila tendrá 24 elementos) y cada una de las filas se asignará a
un día del mes (supongamos que cada mes tiene 31 días, por lo que necesita 31 filas).
Aquí está el par apropiado de comprensiones( h es para las horas, d para el día):
Toda la matriz está llena de ceros ahora. Puede suponer que se actualiza
automáticamente utilizando agentes de hardware especiales. Lo que tienes que hacer es
esperar a que la matriz se llene con las mediciones.
suma = 0.0
promedio= suma / 31
print("Temperatura promedio al mediodía:", promedio)
Nota: La variable day utilizada por el bucle for no es un escalar: cada paso a través de la
matriz temps lo asigna a la siguiente fila de la matriz; Por lo tanto, es una lista. Se debe
indexar con 11 para acceder al valor de temperatura medida al mediodía.
mas_alta = -100.0
Nota:
hotDays = 0
Arreglos tridimensionales
Python no limita la profundidad de la inclusión lista en lista. Aquí puedes ver un ejemplo de
un arreglo tridimensional:
Imagina un hotel. Es un hotel enorme que consta de tres edificios, de 15 pisos cada uno.
Hay 20 habitaciones en cada piso. Para esto, necesitas un arreglo que pueda recopilar y
procesar información sobre las habitaciones ocupadas/libres.
Primer paso: El tipo de elementos del arreglo. En este caso, sería un valor booleano
( True / False ).
Ahora ya puedes reservar una habitación para dos recién casados: en el segundo edificio,
en el décimo piso, habitación 14:
habitaciones[1][9][13] = True
habitaciones[0][4][1] = False
vacante = 0
if not habitaciones[2][14][numeroHabitacion]:
vacante += 1
La variable vacante contiene 0 si todas las habitaciones están ocupadas, o en dado caso
el número de habitaciones disponibles.
¡Felicitaciones! Has llegado al final del módulo. ¡Sigue con el buen trabajo!
Puntos clave
if condicional:
expresión
2. Puedes usar listas anidadas en Python para crear matrices (es decir, listas
bidimensionales). Por ejemplo:
# Una tabla de cuatro columnas y cuatro filas: un arreglo
bidimensional (4x4)
print(tabla)
print(cubo)
¡Bien hecho! Has llegado al final del Módulo 3 y has completado una meta
importante en tu educación de programación en Python. He aquí un breve
resumen de los objetivos que has cubierto y con lo que te has familiarizado en
el Módulo 3:
Ahora estás listo para tomar la prueba del módulo e intentar el desafío final: la
Prueba del Módulo 3, que te ayudará a evaluar lo que has aprendido hasta
ahora.