Modulo 3f
Modulo 3f
1 Sección 1 – Toma de
decisiones en Python
Si, es cierto.
No, esto es falso.
Nunca obtendrás una respuesta como Déjame pensar...., no lo sé, o probablemente sí,
pero no lo sé con seguridad.
Es un operador binario con enlazado del lado izquierdo. Necesita dos argumentos y
verifica si son iguales.
3.1.3 Ejercicios
2 == 2
Revisar
Revisar
1 == 2
Revisar
3.1.4 Operadores
var == 0
Toma 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.
black_sheep == 2 * white_sheep
Debido a la baja prioridad del operador == , la pregunta será tratada como la siguiente:
black_sheep == (2 * white_sheep)
El operador != (no es igual a) también compara los valores de dos operandos. Aquí está
la diferencia: si son iguales, el resultado de la comparación es False . Si no son iguales,
el resultado de la comparación es True .
También se puede hacer una pregunta de comparación usando el operador > (mayor
que).
Si deseas saber si hay más ovejas negras que blancas, puedes escribirlo de la siguiente
manera:
black_sheep > white_sheep # Mayor que
Ambos operadores (estrictos y no estrictos), así como los otros dos que se analizan en
la siguiente sección, son operadores binarios con enlazado del 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:
¿Qué puedes hacer con la respuesta (es decir, el resultado de una operación de
comparación) que se obtiene de la computadora?
Necesitas una instrucción especial para este propósito, y la discutiremos muy pronto.
Ahora necesitamos actualizar nuestra tabla de prioridades, y poner todos los nuevos
operadores en ella. Ahora se ve como a continuación:
Prioridad Operador
1 + , - unario
2 **
3 * , / , // , %
4 + , - binario
6 == , !=
LAB
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 if 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
Output
55
False
Output
99
False
Output
100
True
Output
101
True
Output
-5
False
Entrada de muestra: Salida esperada:
Output
+123
True
Console
Solución de muestra
3.1.7 Condiciones y ejecución
condicional
Ya sabes como hacer preguntas a Python, pero aún no sabes como hacer un uso
razonable de las respuestas. Se debe tener un mecanismo que le permita hacer algo si
se cumple una condición, y no hacerlo si no se cumple.
Es como en la vida real: haces ciertas cosas o no cuando se cumple una condición
específica, por ejemplo, sales a caminar si el clima es bueno, o te quedas en casa si está
húmedo y frío.
Para tomar tales decisiones, Python ofrece una instrucción especial. Debido a su
naturaleza y su aplicación, se denomina instrucción condicional (o sentencia
condicional).
La primera forma de una sentencia condicional, que puede ver a continuación, está
escrita de manera muy informal pero figurada:
if true_or_not:
do_this_if_true
después, almorzaremos
Como puedes ver, almorzar no es una actividad condicional y no depende del clima.
1 if the_weather_is_good:
2 go_for_a_walk()
3 have_lunch()
4
Puedes leerlo como sigue: si sheep_counter es mayor o igual que 120 , entonces duerme
y sueña (es decir, ejecuta la función sleep_and_dream ).
Hemos dicho que las sentencias condicionales deben tener sangría. Esto crea una
estructura muy legible, demostrando claramente todas las rutas de ejecución posibles en
el código.
Como puedes ver, tender la cama, tomar una ducha y dormir y soñar se ejecutan
condicionalmente - cuando sheep_counter alcanza el límite deseado.
Alimentar a los perros, sin embargo, siempre se hace (es decir, la función
feed_the_sheepdogs() no tiene sangría y no pertenece al bloque if , lo que significa que
siempre se ejecuta).
Ahora vamos a discutir otra variante de la sentencia condicional, que también permite
realizar una acción adicional cuando no se cumple la condición.
Comenzamos con una frase simple que decía: Si el clima es bueno, saldremos a
caminar.
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 sentencia condicional, la sentencia if-else:
1 if true_or_false_condition:
2 perform_if_condition_true
3 else:
4 perform_if_condition_false
5
Por lo tanto, hay una nueva palabra: else - esta es una palabra clave 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).
1 if the_weather_is_good:
2 go_for_a_walk()
3 else:
4 go_to_a_theater()
5 have_lunch()
6
Todo lo que hemos dicho sobre la sangría funciona de la misma manera dentro de la
rama else:
1 if the_weather_is_good:
2 go_for_a_walk()
3 have_fun()
4 else:
5 go_to_a_theater()
6 enjoy_the_movie()
7 have_lunch()
8
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.
1 if the_weather_is_good:
2 if nice_restaurant_is_found:
3 have_lunch()
4 else:
5 eat_a_sandwich()
6 else:
7 if tickets_are_available:
8 go_to_the_theater()
9 else:
10 go_shopping()
La sentencia elif
El segundo caso especial presenta otra nueva palabra clave de Python: elif. Como
probablemente sospechas, es una forma más corta de else if.
elif se usa para verificar más de una condición, y para detener cuando se encuentra
la primera sentencia verdadera.
Nuestro siguiente ejemplo se parece a la anidación, pero las similitudes son muy leves.
Nuevamente, cambiaremos nuestros planes y los expresaremos de la siguiente manera:
si hay buen clima, saldremos a caminar, de lo contrario, si obtenemos entradas, iremos
al cine, de lo contrario, si hay mesas libres en el restaurante, vamos a almorzar; si todo
falla, regresaremos a casa y jugaremos ajedrez.
¿Has notado cuantas veces hemos usado las palabras de lo contrario? Esta es la etapa
en la que la palabra clave reservada elif desempeña su función.
1 if the_weather_is_good:
2 go_for_a_walk()
3 elif tickets_are_available:
4 go_to_the_theater()
5 elif table_is_available:
6 go_for_lunch()
7 else:
8 play_chess_at_home()
9
Esto puede sonar un poco desconcertante, pero ojalá que algunos ejemplos simples
ayuden a comprenderlo mejor.
3.1.8 Análisis de muestras de código
Ejemplo 1:
Comenzaremos con el caso más simple - ¿cómo identificar el mayor de los dos
números?:
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:
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.
Suponemos que el primer valor es el más grande. Luego verificamos esta hipótesis con
los dos valores restantes.
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.
1
2
Console
1 largest_number = -999999999
2 number = int(input())
3 if number == -1:
4 print(largest_number)
5 exit()
6 if number > largest_number:
7 largest_number = number
8 # Ir a la línea 02
9
En primer lugar, podemos simplificar el programa si, al principio del código, le asignamos
a la variable largest_number un valor que será más pequeño que cualquiera de los
números ingresados. Usaremos -999999999 para ese propósito.
En segundo lugar, asumimos que nuestro algoritmo no sabrá por adelantado cuántos
números se entregarán al programa. Esperamos que el usuario ingrese todos los
números que desee - el algoritmo funcionará bien con cien y con mil números. ¿Cómo
hacemos eso?
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.
El truco se basa en la suposición de que cualquier parte del código se puede realizar
más de una vez - precisamente, tantas veces como sea necesario.
La ejecución de una determinada parte del código más de una vez se denomina bucle.
El significado de este término es probablemente obvio para ti.
Las líneas 02 al 08 forman un bucle. Los pasaremos tantas veces como sea
necesario para revisar todos los valores ingresados.
¿Puedes usar una estructura similar en un programa escrito en Python? Si, si puedes.
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:
De la misma manera, puedes usar la función min() para devolver el número más
pequeño. Puedes reconstruir el código anterior y experimentar con él en Sandbox.
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.
LAB
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 , grite 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:
imprima el enunciado "Si - ¡El Espatifilo! es la mejor planta de todos los tiempos!"
en la pantalla si la cadena ingresada es "ESPATIFILIO" (mayúsculas)
imprima "No, ¡quiero un gran Espatifilo!" si la cadena ingresada es "espatifilo"
(minúsculas)
imprima "¡Espatifilo!, ¡No [entrada]!" de lo contrario. Nota: [entrada] es la
cadena que se toma como entrada.
Datos de Prueba:
Entrada de muestra: Salida esperada:
Output
espatifilo
No, ¡quiero un gran Espatifilo!
Output
pelargonio
¡Espatifilo!, ¡No pelargonio!
Output
Espatifilo
Si, ¡El Espatifilo! es la mejor planta d
Console
Solución de muestra
LAB
Escenario
Érase una vez una tierra de leche y miel - habitada por gente feliz y próspera. La gente
pagaba impuestos, por supuesto - su felicidad tenía límites. El impuesto más importante,
denominado Impuesto Personal de Ingresos (IPI, para abreviar) tenía que pagarse una
vez al año y se evaluó utilizando la siguiente regla:
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
Output
10000
El impuesto es: 1244.0 pesos
Output
100000
El impuesto es: 19470.0 pesos
Output
1000
El impuesto es: 0.0 pesos
-100
El impuesto es: 0.0 pesos
Console
Solución de muestra
LAB
3.1.12 LAB Fundamentos de la
sentencia if-elif-else
Escenario
Como seguramente sabrás, debido a algunas razones astronómicas, el año puede ser
bisiesto o común. Los primeros tienen una duración de 366 días, mientras que los
últimos tienen una duración de 365 días.
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: Salida esperada:
Output
2000
Año bisiesto
Output
2015
Año comun
Output
1999
Año comun
Output
1996
Año bisiesto
Output
1580
No dentro del período del calendario gre
Console
Solución de muestra
lo contrario.
de lo contrario.
2. Cuando deseas ejecutar algún código solo si se cumple una determinada condición,
puedes usar una sentencia condicional:
1 x = 10
2
3 if x == 10: # condición
4 print("x es igual a 10") # Ejecutado si la condición es True.
5
Una serie de sentencias if , por ejemplo:
1 x = 10
2
3 if x > 5: # primera condición
4 print("x es mayor que 5") # Ejecutado si la primera condición es True.
5
6 if x < 10: # segunda condición
7 print("x es menor que 10") # Ejecutado si la segunda condición es True.
8
9 if x == 10: # tercera condición
10 print("x es igual a 10") # Ejecutado si la tercera condición es True.
11
1 x = 10
2
3 if x < 10: # condición
4 print("x es menor que 10") # Ejecutado si la condición es True.
5
6 else:
7 print("x es mayor o igual a 10") # Ejecutado si la condición es False.
8
1 x = 10
2
3 if x > 5: # primera condición
4 print("x es mayor que 5") # Ejecutado si la primera condición es True.
5
6 if x < 10: # segunda condición
7 print("x es menor que 10") # Ejecutado si la segunda condición es True.
8
9 if x == 10: # tercera condición
10 print("x es igual a 10") # Ejecutado si la tercera condición es True.
11
1 x = 10
2
3 if x == 10: # True
4 print("x == 10")
5
6 if x > 15: # False
7 print("x > 15")
8
9 elif x > 10: # False
10 print("x > 10")
11
12 elif x > 5: # True
13 print("x > 5")
14
15 else:
16 print("else no será ejecutado")
17
1 x = 10
2
3 if x > 5: # True
4 if x == 6: # False
5 print("anidado: x == 6")
6 elif x == 10: # True
7 print("anidado: x == 10")
8 else:
9 print("anidado: else")
10 else:
11 print("else")
12
print(x > y)
print(y > z)
Revisar
x, y, z = 5, 10, 8
print(x > z)
print((y - 5) == x)
Revisar
print(x > z)
print((y - 5) == x)
Revisar
x = 10
if x == 10:
print(x == 10)
if x > 5:
print(x > 5)
if x < 10:
print(x < 10)
else:
print("else")
Revisar
Pregunta 5: ¿Cuál es el resultado del siguiente fragmento de código?
x = "1"
if x == 1:
print("one")
elif x == "1":
if int(x) > 1:
print("two")
elif int(x) < 1:
print("three")
else:
print("four")
if int(x) == 1:
print("five")
else:
print("six")
Revisar
x = 1
y = 1.0
z = "1"
if x == y:
print("one")
if y == int(z):
print("two")
elif x == y:
print("three")
else:
print("four")
Revisar
3.2 Sección 2 – Bucles
en Python
Toma en cuenta que este registro también declara que, si no hay nada que hacer, nada
ocurrirá.
while
instruction
Si observas algunas similitudes con la instrucción if, está bien. De hecho, la diferencia
sintáctica es solo una: usa la palabra while en lugar de la palabra if .
Nota: todas las reglas relacionadas con sangría también se aplican aquí. Te mostraremos
esto pronto.
Observa el algoritmo a continuación:
while conditional_expression:
instruction_one
instruction_two
instruction_three
:
:
instruction_n
si deseas ejecutar más de una sentencia dentro de un while , debes (como con
if ) poner sangría a todas las instrucciones de la misma manera.
una instrucción o conjunto de instrucciones ejecutadas dentro del while se llama el
cuerpo del bucle.
si la condición es False (igual a cero) tan pronto como se compruebe por primera
vez, el cuerpo no se ejecuta ni una sola vez (ten en cuenta la analogía de no tener
que hacer nada si no hay nada que hacer).
el cuerpo debe poder cambiar el valor de la condición, porque si la condición es
True al principio, el cuerpo podría funcionar continuamente hasta el infinito.
Observa que hacer una cosa generalmente disminuye la cantidad de cosas por
hacer.
3.2.2 Un bucle infinito
Un bucle infinito, también denominado bucle sin fin, es una secuencia de instrucciones
en un programa que se repite indefinidamente (bucle sin fin).
1 while True:
2 print("Estoy atrapado dentro de un bucle.")
3
Nota
Veamos otro ejemplo utilizando el bucle while . Sigue los comentarios para descubrir la
idea y la solución.
Intenta recordar cómo Python interpreta la verdad de una condición y ten en cuenta que
estas dos formas son equivalentes:
if number % 2 == 1: y if number % 2: .
1 counter = 5
2 while counter != 0:
3 print("Dentro del bucle.", counter)
4 counter -= 1
5 print("Fuera del bucle.", counter)
6
Este código está destinado a imprimir la cadena "Dentro del bucle." y el valor
almacenado en la variable counter durante un bucle dado exactamente cinco veces. Una
vez que la condición se haya cumplido (la variable counter ha alcanzado 0 ), se sale del
bucle y aparece el mensaje "Fuera del bucle." así como tambien el valor almacenado en
counter se imprime.
Pero hay una cosa que se puede escribir de forma más compacta - la condición del
bucle while .
1 counter = 5
2 while counter:
3 print("Dentro del bucle.", counter)
4 counter -= 1
5 print("Fuera del bucle.", counter)
6
¿Es más compacto que antes? Un poco. ¿Es más legible? Eso es discutible.
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.
LAB
Escenario
Un mago junior ha elegido un número secreto. Lo ha escondido en una variable llamada
secret_number . Quiere que todos los que ejecutan su programa jueguen el juego Adivina
el número secreto, y adivina qué número ha elegido para ellos. ¡Quiénes no adivinen el
número quedarán atrapados en un bucle sin fin para siempre! Desafortunadamente, él no
sabe cómo completar el código.
INFO EXTRA
Por cierto, observa la función print() . La forma en que lo hemos utilizado aquí se llama
impresión multilínea. Puedes 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.
1 secret_number = 777
2
3 print(
4 """
5 +================================+
6 | ¡Bienvenido a mi juego, muggle!|
7 | Introduce un número entero |
8 | y adivina qué número he |
9 | elegido para ti. |
10 |¿Cuál es el número secreto? |
11 +================================+
12 """)
13
14
Console
1 i = 0
2 while i < 100:
3 # do_something()
4 i += 1
5
Sería bueno si alguien pudiera hacer esta cuenta aburrida por ti. ¿Es eso posible?
Por supuesto que lo es - hay un bucle especial para este tipo de tareas, y se llama for .
En realidad, el bucle for está diseñado para realizar tareas más complicadas, puede
"explorar" grandes colecciones de datos elemento por elemento. Te mostraremos
como hacerlo pronto, pero ahora presentaremos una variante más sencilla de su
aplicación.
1 for i in range(100):
2 # do_something()
3 pass
4
la palabra reservada for abre el bucle for ; nota - No hay condición después de
eso; no tienes que pensar en las condiciones, ya que se verifican internamente, sin
ninguna intervención.
cualquier variable después de la palabra reservada for es la variable de control del
bucle; cuenta los giros del bucle y lo hace automáticamente.
la palabra reservada in introduce un elemento de sintaxis que describe el rango de
valores posibles que se asignan a la variable de control.
la función range() (esta es una función muy especial) es responsable de generar
todos los valores deseados de la variable de control; en nuestro ejemplo, la función
creará (incluso podemos decir que alimentará el bucle con) valores subsiguientes
del siguiente conjunto: 0, 1, 2 .. 97, 98, 99; nota: en este caso, la función range()
comienza su trabajo desde 0 y lo finaliza un paso (un número entero) antes del
valor de su argumento.
nota la palabra clave pass dentro del cuerpo del bucle - no hace nada en absoluto;
es una instrucción vacía - la colocamos aquí porque la sintaxis del bucle for
exige al menos una instrucción dentro del cuerpo (por cierto - if , elif , else y
while expresan lo mismo).
1 for i in range(10):
2 print("El valor de i es", i)
3
Console
Nota:
La invocación de la función range() puede estar equipada con dos argumentos, no solo
uno:
Nota: la función range() solo acepta enteros como argumentos y genera secuencias
de enteros.
¿Puedes adivinar la output del programa? Ejecútalo para comprobar si ahora también
estabas en lo cierto.
Console
Output
El valor de i es 2
El valor de i es 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 output). 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.
Nota: si el conjunto generado por la función range() está vacío, el bucle no ejecutará su
cuerpo en absoluto.
Echemos un vistazo a un programa corto cuya tarea es escribir algunas de las primeras potencias
de dos:
1 power = 1
2 for expo in range(16):
3 print("2 a la potencia de", expo, "es", power)
4 power *= 2
5
Console
La variable expo se utiliza como una variable de control para el bucle 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?
LAB
3.2.7 LAB Fundamentos del bucle for –
contando lentamente (mississippily)
Escenario
¿Sabes lo que es Mississippi? Bueno, es el nombre de uno de los estados y ríos en los
Estados Unidos. El río Mississippi tiene aproximadamente 2,340 millas de largo, lo que lo
convierte en el segundo río más largo de los Estados Unidos (el más largo es el río
Missouri). ¡Es tan largo que una sola gota de agua necesita 90 días para recorrer toda su
longitud!
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 bucle for para "contar de
forma mississippi" hasta cinco. Habiendo contado hasta cinco, el programa debería
imprimir en la pantalla el mensaje final "¡Listos 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 sentencia 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 bucle 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:
Output
1 Mississippi
2 Mississippi
3 Mississippi
4 Mississippi
5 Mississippi
1 import time
2
3 # Escribe un bucle for que cuente hasta cinco.
4 # Cuerpo del bucle: imprime el número de iteración del bucle y la palabra "
5 # Cuerpo del bucle, emplea : time.sleep(1)
6
7 # Escribe una función print con el mensaje final.
8
9
Console
3.2.8 Las sentencias break y continue
Hasta ahora, hemos tratado el cuerpo del bucle como una secuencia indivisible e
inseparable de instrucciones que se realizan completamente en cada giro del bucle. Sin
embargo, como desarrollador, podrías enfrentar las siguientes opciones:
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 output.
Modifica el código y experimenta.
1 # break - ejemplo
2
3 print("La instrucción break:")
4 for i in range(1, 6):
5 if i == 3:
6 break
7 print("Dentro del bucle.", i)
8 print("Fuera del bucle.")
9
10
11 # continue - ejemplo
12
13 print("\nLa instrucción continue:")
14 for i in range(1, 6):
Console
1 largest_number = -99999999
2 counter = 0
3
4 while True:
5 number = int(input("Ingresa un número o escribe -1 para finalizar el pro
6 if number == -1:
7 break
8 counter += 1
9 if number > largest_number:
10 largest_number = number
11
12 if counter != 0:
13 print("El número más grande es", largest_number)
14 else:
Console
Ejecútalo, pruébalo y experimenta con él.
1 largest_number = -99999999
2 counter = 0
3
4 number = int(input("Ingresa un número o escribe -1 para finalizar el program
5
6 while number != -1:
7 if number == -1:
8 continue
9 counter += 1
10
11 if number > largest_number:
12 largest_number = number
13 number = int(input("Ingresa un número o escribe -1 para finalizar el pro
14
Console
Observa con atención, el usuario ingresa el primer número antes de que el programa ingrese al
bucle while . El número siguiente se ingresa cuando el programa ya está en el bucle.
Escenario
La instrucción break se implementa para salir/terminar un bucle.
Diseña un programa que use un bucle while y le pida continuamente al usuario que
ingrese una palabra a menos que ingrese "chupacabra" como la palabra de output
secreta, en cuyo caso el mensaje "Has dejado el bucle con éxito." debe imprimirse en la
pantalla y el bucle debe terminar.
Console
LAB
Escenario
un bucle for ;
el concepto de ejecución condicional (if-elif-else).
la sentencia continue .
Tu programa debe:
Datos de Prueba:
Output
Gregory
G
R
G
R
Y
Output
abstemious
B
S
T
M
S
IOUEA
Output
Console
LAB
3.2.11 LAB La sentencia continue – el
Lindo Devorador de Vocales
Escenario
Tu tarea aquí es aún más especial que antes: ¡Debes rediseñar el devorador de vocales
(feo) del laboratorio anterior y crear un mejor devorador de vocales (lindo) mejorado!
Escribe un programa que use:
un bucle for .
el concepto de ejecución condicional (if-elif-else).
la instrucción continue .
Tu programa debe:
Datos de Prueba:
Entrada de muestra: Salida esperada:
Output
Gregory
GRGRY
Output
abstemious
BSTMS
Output
IOUEA
1 word_without_vowels = ""
2
3 # Indicar al usuario que ingrese una palabra
4 # y asignarla a la variable user_word.
5
6
7 for letter in user_word:
8 # Completa el cuerpo del bucle.
9
10 # Imprimir la palabra asignada a word_without_vowels.
11
12
Console
3.2.12 El bucle while y el bloque else
Ambos bucles while y for , tienen una característica interesante (y rara vez se usa).
En otras palabras, trata de convencerte si la función es valiosa y útil, o solo es azúcar sintáctica.
Echa un vistazo al fragmento en el editor. Hay algo extraño al final - la palabra reservada else .
Como pudiste haber sospechado, los bucles también pueden tener la rama else , como los if .
La rama else del bucle siempre se ejecuta una vez, independientemente de si el bucle ha
entrado o no en su cuerpo.
1 i = 1
2 while i < 5:
3 print(i)
4 i += 1
5 else:
6 print("else:", i)
7
8
Console
Modifica el fragmento un poco para que el bucle no tenga oportunidad de ejecutar su cuerpo ni
una sola vez:
1 i = 5
2 while i < 5:
3 print(i)
4 i += 1
5 else:
6 print("else:", i)
7
8
Console
1 for i in range(5):
2 print(i)
3 else:
4 print("else:", i)
5
6
Console
1 i = 111
2 for i in range(2, 1):
3 print(i)
4 else:
5 print("else:", i)
6
7
Console
El cuerpo del bucle no se ejecutará aquí en absoluto. Nota: hemos asignado la variable
i antes del bucle.
Cuando el cuerpo del bucle no se ejecuta, la variable de control conserva el valor que
tenía antes del bucle.
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. Pero primero hagamos algunos
laboratorios.
LAB
Escenario
Datos de Prueba
Output
6
La altura de la pirámide es: 3
20
Output
La altura de la pirámide: 3
Output
1000
La altura de la pirámide: 44
Output
2
La altura de la pirámide: 1
Console
LAB
Escenario
En 1937, un matemático alemán llamado Lothar Collatz formuló una hipótesis intrigante
(aún no se ha comprobado) que se puede describir de la siguiente manera:
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.
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 bucle while - esta es la clave del éxito.
Datos de Prueba:
Output
15
46
46
70
35
106
53
160
80
40
20
10
5
16
8
4
2
1
pasos = 17
16
8
4
2
1
pasos = 4
1023
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
173
260
130
65
196
98
49
148
74
37
37
56
28
14
7
22
11
34
17
52
26
13
40
20
10
5
16
8
4
2
pasos = 62
1
Console
El bucle while ejecuta una sentencia o un conjunto de sentencias siempre que una
condición booleana especificada sea verdadera, por ejemplo:
1 # Ejemplo 1
2 while True:
3 print("Atrapado en un bucle infinito.")
4
5 # Ejemplo 2
6 counter = 5
7 while counter > 2:
8 print(counter)
9 counter -= 1
10
El bucle for ejecuta un conjunto de sentencias muchas veces; se usa para iterar
sobre una secuencia (por ejemplo, una lista, un diccionario, una tupla o un
conjunto; pronto aprenderás sobre ellos) u otros objetos que son iterables (por
ejemplo, cadenas). Puedes usar el bucle for para iterar sobre una secuencia de
números usando la función incorporada range . Mira los ejemplos a continuación:
1 # Ejemplo 1
2 word = "Python"
3 for letter in word:
4 print(letter, end="*")
5
6 # Ejemplo 2
7 for i in range(1, 10):
8 if i % 2 == 0:
9 printprint(i)
10
2. Puedes usar las sentencias break y continue para cambiar el flujo de un bucle:
Utiliza continue para omitir la iteración actual, y continuar con la siguiente iteración,
por ejemplo:
1 text = "pyxpyxpyx
2 for letter in text:
3 if letter == "x":
4 continue
5 print(letter, end="")
6
3. Los bucles while y for también pueden tener una cláusula else en Python. La
cláusula else se ejecuta después de que el bucle finalice su ejecución siempre y
cuando no haya terminado con break , por ejemplo:
1 n = 0
2
3 while n != 3:
4 print(n)
5 n += 1
6 else:
7 print(n, "else")
8
9 print()
10
11 for i in range(0, 3):
12 print(i)
13 else:
14 print(i, "else")
15
1 for i in range(3):
2 print(i, end=" ") # output: 0 1 2
3
4 for i in range(6, 1, -2):
5 print(i, end=" ") # output: 6, 4, 2
6
Pregunta 1: Crea un bucle for que cuente de 0 a 10, e imprima números impares en la
pantalla. Usa el esqueleto de abajo:
Revisar
Pregunta 2: Crea un bucle while que cuente de 0 a 10, e imprima números impares en
la pantalla. Usa el esqueleto de abajo:
x = 1
while x < 11:
# Línea de código.
# Línea de código.
# Línea de código.
Revisar
Pregunta 3: Crea un programa con un bucle for y una sentencia 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
Pregunta 4: Crea un programa con un bucle for y una sentencia continue . El programa
debe iterar sobre una cadena de dígitos, reemplazar cada 0 con x , e imprimir la
cadena modificada en la pantalla. Usa el esqueleto de abajo:
n = 3
while n > 0:
print(n + 1)
n -= 1
else:
print(n)
Revisar
n = range(4)
for num in n:
print(num - 1)
else:
print(num)
Revisar
Revisar
3.3 Sección 3 –
Operaciones lógicas y
de bits en Python
En esta sección, aprenderás sobre los operadores lógicos y de bit a bit en Python,
conceptos como las tablas de verdad y el desplazamiento de bits.
3.3.1 Lógica de computadoras
¿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 este enunciado:
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:
Está claro que Python debe tener operadores para construir conjunciones y
disyunciones. Sin ellos, el poder expresivo del lenguaje se debilitaría sustancialmente.
Se llaman operadores lógicos.
El operador and
Un operador de conjunción lógica en Python es la palabra and. 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:
El operador 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
Este operador se escribe como la palabra not , y su prioridad es muy alta: igual que el
unario + y - . Su tabla de verdad es simple:
False True
True False
Creemos una variable llamada var y asignémosle 1 . Las siguientes condiciones son
equivalentes a pares:
1 # Ejemplo 1:
2 print(var > 0)
3 print(not (var <= 0))
4
5
6 # Ejemplo 2:
7 print(var != 0)
8 print(not (var == 0))
9
Observa como se han utilizado los paréntesis para codificar las expresiones - las
colocamos allí para mejorar la legibilidad.
El resultado de sus operaciones es uno de estos valores: False o True . Esto significa
que este fragmento de código asignará el valor True a la variable j si i no es cero; de
lo contrario, será False .
1 i = 1
2 j = not not i
3
Sin embargo, hay cuatro operadores que le permiten manipular bits de datos
individuales. Se denominan operadores bit a bit.
0 0 0 0 0
0 1 0 1 1
1 0 0 1 1
1 1 1 1 0
Argumento ~ Argumento
0 1
1 0
Los operadores bit a bit 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).
1 i = 15
2 j = 22
3
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:
1 log = i and j
2
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
Ahora la operación a nivel de bits - aquí está:
1 bit = i & j
2
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 00000000000000000000000000001111
j 00000000000000000000000000010110
1 logneg = not i
2
1 bitneg = ~i
2
Puede ser un poco sorprendente: el valor de la variable bitneg es -16 . Esto puede
parecer extraño, pero no lo es en absoluto. Si deseas obtener más información, debes
consultar el sistema de números binarios y las reglas que rigen los números de
complemento de dos.
i 00000000000000000000000000001111
bitneg = ~i 11111111111111111111111111110000
x = x & y x &= y
x = x | y x |= y
x = x ^ y x ^= y
Ahora te mostraremos para que puedes usar los operadores de bit a bit. Imagina que
eres un desarrollador obligado a escribir una pieza importante de un sistema operativo.
Se te ha dicho que puedes usar una variable asignada de la siguiente forma:
flag_register = 0x1234
flag_register = 0000000000000000000000000000x000
1 x & 1 = x
2 x & 0 = 0
3
00000000000000000000000000001000
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 sentencia:
1 the_mask = 8
2
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
Toma en cuenta que la máscara se creó como resultado de la negación de todos los bits
de la variable the_mask . Restablecer el bit es simple, y se ve así (elige el que más te
guste):
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:
1 x | 1 = 1
2 x | 0 = x
3
Ya estás listo para configurar su bit con una de las siguientes instrucciones:
1 x ^ 1 = ~x
2 x ^ 0 = x
3
Python ofrece otra operación relacionada con los bits individuales: shifting. Esto se
aplica solo a los valores de número entero, y no debe usar flotantes como argumentos
para ello.
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
Los operadores de cambio en Python son un par de dígrafos: < < y > > , sugiriendo
claramente en qué dirección actuará el cambio.
1 var = 17
2 var_right = var >> 1
3 var_left = var << 2
4 print(var, var_left, var_right)
5
Console
La invocación final de print() produce el siguiente resultado:
Output
17 68 8
Nota:
Y aquí está la tabla de prioridades actualizada , que contiene todos los operadores
presentados hasta ahora:
Prioridad Operador
1 ~ , +, - unario
2 **
3 * , / , // , %
4 + , - binario
5 << , >>
7 == , !=
8 &
9 |
2. Puedes utilizar operadores bit a bit para manipular bits de datos individuales. Los
siguientes datos de muestra:
Se utilizarán para ilustrar el significado de operadores bit a bit en Python. Analiza los
ejemplos a continuación:
& 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.
* -16 (decimal del complemento a 2 con signo) -- lee más acerca de la operación
Complemento a dos.
1 x = 1
2 y = 0
3
4 z = ((x == y) and (x == y)) or not(x == y)
5 print(not(z))
6
Revisar
Pregunta 2: ¿Cuál es el resultado del siguiente fragmento de código?
1 x = 4
2 y = 1
3
4 a = x & y
5 b = x | y
6 c = ~x # ¡difícil!
7 d = x ^ 5
8 e = x >> 2
9 f = x << 2
10
11 print(a, b, c, d, e, f)
12
Revisar
3.4 Sección 4 – Listas
¡Bienvenido la sección 4! Aquí aprenderás sobre las listas de Python y cómo realizar
varias operaciones en ellas. Aprenderás a cómo indexar, actualizar y eliminar elementos
de lista, cómo crear rodajas y cómo usar algunas de las funciones y métodos de lista
más importantes.
3.4.1 ¿Por qué necesitamos listas?
Puede suceder que tengas que leer, almacenar, procesar y, finalmente, imprimir
docenas, quizás cientos, tal vez incluso miles de números. ¿Entonces qué? ¿Necesitas
crear una variable separada para cada valor? ¿Tendrás que pasar largas horas
escribiendo sentencias como la que se muestra a continuación?
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:
Debes percatarte que ni siquiera tienes suficiente papel para completar la tarea.
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?
¿Y si solo pudieras numerarlos? Y luego di: dame el valor número 2; asigna el valor
número 15; aumenta el número del valor 10000.
Te mostraremos como declarar tales variables de múltiples valores. Haremos esto con
el ejemplo que acabamos de sugerir. Escribiremos un programa que ordene una
secuencia de números. No seremos particularmente ambiciosos - asumiremos que hay
exactamente cinco números.
Vamos a crear una variable llamada numbers ; se le asigna no solo un número, sino que se
llena con una lista que consta de cinco valores (nota: la lista comienza con un corchete
abierto y termina con un corchete cerrado; el espacio entre los corchetes es llenado
con cinco números separados por comas).
numbers = [10, 5, 7, 2, 1]
Digamos lo mismo utilizando una terminología adecuada: numbers es una lista que
consta de cinco valores, todos ellos números. También podemos decir que esta
sentencia crea una lista de longitud igual a cinco (ya que contiene cinco elementos).
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.
Antes de continuar con nuestra discusión, debemos indicar lo siguiente: nuestra lista es
una colección de elementos, pero cada elemento es un escalar.
3.4.2 Indexación de listas
1 numbers = [10, 5, 7, 2, 1]
2 print("Contenido de la lista:", numbers) # Imprimiendo contenido de la lista
3
4 numbers[0] = 111
5 print("Nuevo contenido de la lista: ", numbers) # Contenido actual de la list
6
Y ahora queremos copiar el valor del quinto elemento al segundo elemento - ¿puedes
adivinar cómo hacerlo?
1 numbers = [10, 5, 7, 2, 1]
2 print("Contenido de la lista original:", numbers) # Imprimiendo contenido de
3
4 numbers[0] = 111
5 print("\nPrevio contenido de la lista:", numbers) # Imprimiendo contenido de
6
7 numbers[1] = numbers[4] # Copiando el valor del quinto elemento al segundo e
8 print("Nuevo contenido de la lista:", numbers) # Imprimiendo el contenido de
9
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.
Se puede acceder a cada uno de los elementos de la lista por separado. Por ejemplo, se
puede imprimir:
1 numbers = [10, 5, 7, 2, 1]
2 print("Contenido de la lista original:", numbers) # Imprimiendo el contenido
3
4 numbers[0] = 111
5 print("\nContenido de la lista con cambio:", numbers) # Imprimiendo contenido
6
7 numbers[1] = numbers[4] # Copiando el valor del quinto elemento al segundo el
8 print("Contenido de la lista con intercambio:", numbers) # Imprimiendo conten
9
10 print("\nLongitud de la lista:", len(numbers)) # Imprimiendo la longitud de l
11
Console
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 output de una manera que
sugiere que todos los valores presentados forman una lista. La output 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.
Si deseas verificar la longitud actual de la lista, puedes usar una función llamada len()
(su nombre proviene de length - longitud).
Observa la última línea de código en el editor, ejecuta el programa y verifica que valor
imprimirá en la consola. ¿Puedes adivinar?
Cualquier elemento de la lista puede ser eliminado en cualquier momento - esto se hace
con una instrucción llamada del (eliminar). Nota: es una instrucción, no una función.
1 del numbers[1]
2 print(len(numbers))
3 print(numbers)
4
1 print(numbers[4])
2 numbers[4] = 1
3
1 numbers = [10, 5, 7, 2, 1]
2 print("Contenido de la lista original:", numbers) # Imprimiendo el contenid
3
4 numbers[0] = 111
5 print("\nContenido de la lista con cambio:", numbers) # Imprimiendo conteni
6
7 numbers[1] = numbers[4] # Copiando el valor del quinto elemento al segundo
8 print("Contenido de la lista con intercambio:", numbers) # Imprimiendo cont
9
10 print("\nLongitud de la lista:", len(numbers)) # Imprimiendo la longitud de
11
12 ###
13
14 del numbers[1] # Eliminando el segundo elemento de la lista.
15 print("Longitud de la nueva lista:", len(numbers)) # Imprimiendo nueva long
Console
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.
1 numbers = [111, 7, 2, 1]
2 print(numbers[-1])
3
Console
El código del ejemplo mostrará 1 . Ejecuta el programa y comprueba.
Del mismo modo, el elemento con un índice igual a -2 es el anterior al último en la lista.
1 numbers = [111, 7, 2, 1]
2 print(numbers[-2])
3
Console
El último elemento accesible en nuestra lista es numeros[-4] (el primero) - ¡no intentes ir más lejos!
LAB
3.4.6 LAB Los fundamentos de las
listas
Escenario
Había una vez un sombrero. El sombrero no contenía conejo, sino una lista de cinco números: 1 ,
2, 3, 4,y 5.
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).
Console
3.4.7 Funciones vs métodos
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.
Un método es propiedad de los datos para los que trabaja, mientras que una función
es propiedad de todo el código.
Esto también significa que invocar un método requiere alguna especificación de los
datos a partir de los cuales se invoca el método.
result = function(arg)
La función toma un argumento, hace algo, y devuelve un resultado.
result = 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.
list.append(value)
list.insert(location, value)
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.
Observa el código en el editor. Ve como usamos los métodos append() e insert() . Presta
atención a lo que sucede después de usar insert() : el primer elemento anterior ahora es el
segundo, el segundo el tercero, y así sucesivamente.
1 numbers = [111, 7, 2, 1]
2 print(len(numbers))
3 print(numbers)
4
5 ###
6
7 numbers.append(4)
8
9 print(len(numbers))
10 print(numbers)
11
12 ###
13
14 numbers.insert(0, 222)
Console
1 numbers.insert(1, 333)
2
Puedes iniciar la vida de una lista creándola vacía (esto se hace con un par de corchetes vacíos)
y luego agregar nuevos elementos según sea necesario.
Echa un vistazo al fragmento en el editor. Intenta adivinar su output después de la ejecución del
bucle for . Ejecuta el programa para comprobar si tenías razón.
Console
Será una secuencia de números enteros consecutivos del 1 (luego agrega uno a todos los valores
agregados) hasta 5 .
¿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() ).
3.4.9 Haciendo uso de las listas
El bucle for tiene una variante muy especial que puede procesar las listas de manera muy
efectiva - echemos un vistazo a eso.
1 my_list = [10, 1, 8, 3, 5]
2 total = 0
3
4 for i in range(len(my_list)):
5 total += my_list[i]
6
7 print(total)
8
Console
Supongamos que deseas calcular la suma de todos los valores almacenados en la lista my_list .
1 my_list = [10, 1, 8, 3, 5]
2 total = 0
3
4 for i in my_list:
5 total += i
6
7 print(total)
8
Dejemos de lado las listas por un breve momento y veamos un tema intrigante.
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.
1 variable_1 = 1
2 variable_2 = 2
3
4 variable_2 = variable_1
5 variable_1 = variable_2
6
1 variable_1 = 1
2 variable_2 = 2
3
4 auxiliary = variable_1
5 variable_1 = variable_2
6 variable_2 = auxiliary
7
Python ofrece una forma más conveniente de hacer el intercambio - echa un vistazo:
1 variable_1 = 1
2 variable_2 = 2
3
4 variable_1, variable_2 = variable_2, variable_1
5
Ahora puedes intercambiar fácilmente los elementos de la lista para revertir su orden:
1 my_list = [10, 1, 8, 3, 5]
2
3 my_list[0], my_list[4] = my_list[4], my_list[0]
4 my_list[1], my_list[3] = my_list[3], my_list[1]
5
6 print(my_list)
7
Ejecuta el fragmento. Su output debería verse así:
Output
[5, 3, 8, 1, 10]
¿Seguirá siendo aceptable con una lista que contenga 100 elementos? No, no lo hará.
Nota:
hemos asignado la variable length a la longitud de la lista actual (esto hace que
nuestro código sea un poco más claro y más corto)
hemos preparado el bucle for para que se ejecute su cuerpo length // 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 (length - i - 1) (desde el final de la lista); en nuestro ejemplo, for
i igual a 0 a la (length - i - 1) da 4 ; for i igual a 3 , da 3 - esto es
exactamente lo que necesitábamos.
Escenario
Los Beatles fueron uno de los grupos de música más populares de la década de 1960 y la banda
más vendida en la historia. Algunas personas los consideran el acto más influyente de la era del
rock. De hecho, se incluyeron en la compilación de la revista Time de las 100 personas más
influyentes del siglo XX.
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:
1 # paso 1
2 print("Paso 1:", beatles)
3
4 # paso 2
5 print("Paso 2:", beatles)
6
7 # paso 3
8 print("Paso 3:", beatles)
9
10 # paso 4
11 print("Paso 4:", beatles)
12
13 # paso 5
14 print("Paso 5:", beatles)
Console
Aprenderás más sobre el anidamiento - por el momento, solo queremos que sepas que
algo como esto también es posible.
5.Las listas pueden ser iteradas mediante el uso del bucle for , por ejemplo:
6. La función len() se puede usar para verificar la longitud de la lista, por ejemplo:
1 lst = [1, 2, 3, 4, 5]
2 lst.insert(1, 6)
3 del lst[0]
4 lst.append(1)
5
6 print(lst)
7
Revisar
Revisar
1 lst = []
2 del lst
3 print(lst)
4
Revisar
Revisar
3.5 Sección 5 –
Ordenando listas
simples: el
ordenamiento de
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.
En las siguientes secciones, ordenaremos la lista en orden ascendente, de modo que los
números se ordenen de menor a mayor.
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.
Ahora, por un momento, intenta imaginar la lista de una manera ligeramente diferente -
es decir, de esta manera:
10
8
Observa - El 10 está en la parte superior. Podríamos decir que flotó desde el fondo
hasta la superficie, al igual que las burbujas en una copa de champán. El método de
clasificación deriva su nombre de la misma observación - se denomina ordenamiento
burbuja.
6 8 2 4 10
6 2 8 4 10
6 2 4 8 10
2 6 4 8 10
2 4 6 8 10
La lista ya está ordenada. No tenemos nada más que hacer. Esto es exactamente lo que
queremos.
Como puedes ver, la esencia de este algoritmo es simple: comparamos los elementos
adyacentes y, al intercambiar algunos de ellos, logramos nuestro objetivo.
Codifiquemos en Python todas las acciones realizadas durante un solo paso a través de
la lista, y luego consideraremos cuántos pases necesitamos para realizarlo. No hemos
explicado esto hasta ahora, pero lo haremos pronto.
3.5.2 Ordenando una lista
Console
3.5.3 El ordenamiento burbuja – versión
interactiva
En el editor, puedes ver un programa completo, enriquecido por una conversación con el usuario, y
que permite ingresar e imprimir elementos de la lista: El ordenamiento burbuja - versión final
interactiva.
1 my_list = []
2 swapped = True
3 num = int(input("¿Cuántos elementos deseas ordenar?: "))
4
5 for i in range(num):
6 val = float(input("Ingresa un elemento de la lista: "))
7 my_list.append(val)
8
9 while swapped:
10 swapped = False
11 for i in range(len(my_list) - 1):
12 if my_list[i] > my_list[i + 1]:
13 swapped = True
14 my_list[i], my_list[i + 1] = my_list[i + 1], my_list[i]
Console
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.
Te explicamos este sistema de clasificación porque es importante aprender como procesar los
contenidos de una lista y mostrarte como puede funcionar la clasificación real.
Output
[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.
3.5.4 RESUMEN DE SECCIÓN
1. Puedes usar el método sort() para ordenar los elementos de una lista, por ejemplo:
1 lst = [5, 3, 1, 2, 4]
2 print(lst)
3
4 lst.sort()
5 print(lst) # output: [1, 2, 3, 4, 5]
6
2.También hay un método de lista llamado reverse() , que puedes usar para invertir la
lista, por ejemplo:
1 lst = [5, 3, 1, 2, 4]
2 print(lst)
3
4 lst.reverse()
5 print(lst) # output: [4, 2, 1, 3, 5]
6
3.5.5 QUIZ DE SECCIÓN
Revisar
1 a = 3
2 b = 1
3 c = 2
4
5 lst = [a, c, b]
6 lst.sort()
7
8 print(lst)
9
Revisar
1 a = "A"
2 b = "B"
3 c = "C"
4 d = " "
5
6 lst = [a, b, c, d]
7 lst.reverse()
8
9 print(lst)
10
Revisar
3.6 Sección 6 –
Operaciones con listas
Queremos que lo memorices - ya que puede afectar tus programas futuros y causar graves
problemas si se olvida o se pasa por alto.
1 list_1 = [1]
2 list_2 = list_1
3 list_1[0] = 2
4 print(list_2)
5
Console
El programa:
Las listas (y muchas otras entidades complejas de Python) se almacenan de diferentes maneras
que las variables ordinarias (escalares).
Lee estas dos líneas una vez más - la diferencia es esencial para comprender de que vamos a
hablar a continuación.
La asignación: list_2 = list_1 copia el nombre del arreglo no su contenido. En efecto, los dos
nombres ( list_1 y list_2 ) identifican la misma ubicación en la memoria de la computadora.
Modificar uno de ellos afecta al otro, y viceversa.
Una rebanada es un elemento de la sintaxis de Python que permite hacer una copia
nueva de una lista, o partes de una lista.
1 list_1 = [1]
2 list_2 = list_1[:]
3 list_1[0] = 2
4 print(list_2)
5
Su output es [1] .
Esta parte no visible del código descrito como [:] puede producir una lista
completamente nueva.
my_list[inicio:fin]
Como puedes ver, se asemeja a la indexación, pero los dos puntos en el interior hacen
una gran diferencia.
Una rebanada de este tipo crea una nueva lista (de destino), tomando elementos de la
lista de origen - los elementos de los índices desde el start hasta el fin 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).
1 my_list = [10, 8, 6, 4, 2]
2 new_list = my_list[1:3]
3 print(new_list)
4
La lista new_list contendrá fin - inicio (3 - 1 = 2) elementos ‒ los que tienen índices
iguales a 1 y 2 (pero no 3 ).
Ejecuta el código en el editor para ver cómo Python copia la lista completa y un
fragmento de la lista. ¡Siéntete libre de experimentar!
Console
3.6.3 Rebanadas – índices negativos
my_list[start:end]
Para confirmar:
1 my_list = [10, 8, 6, 4, 2]
2 new_list = my_list[1:-1]
3 print(new_list)
4
Output
[8, 6, 4]
Si start especifica un elemento que se encuentra más allá del descrito por end (desde
el punto de vista inicial de la lista), la rebanada estará vacía:
1 my_list = [10, 8, 6, 4, 2]
2 new_list = my_list[-1:1]
3 print(new_list)
4
Output
[]
my_list[:end]
my_list[0:end]
1 my_list = [10, 8, 6, 4, 2]
2 new_list = my_list[:3]
3 print(new_list)
4
Es por esto que su output es: [10, 8, 6] .
Del mismo modo, si omites el end en tu rebanada, se supone que deseas que el
segmento termine en el elemento con el índice len(my_list) .
my_list[start:]
my_list[start:len(my_list)]
1 my_list = [10, 8, 6, 4, 2]
2 new_list = my_list[3:]
3 print(new_list)
4
Como hemos dicho anteriormente, el omitir el inicio y fin crea una copia de toda la
lista:
1 my_list = [10, 8, 6, 4, 2]
2 new_list = my_list[:]
3 print(new_list)
4
1 my_list = [10, 8, 6, 4, 2]
2 del my_list[1:3]
3 print(my_list)
4
1 my_list = [10, 8, 6, 4, 2]
2 del my_list[:]
3 print(my_list)
4
1 my_list = [10, 8, 6, 4, 2]
2 del my_list
3 print(my_list)
4
Python ofrece dos operadores muy poderosos, capaces de revisar la lista para verificar
si un valor específico está almacenado dentro de la lista o no.
1 elem in my_list
2 elem not in my_list
3
Console
3.6.5 Listas - algunos programas simples
Ahora queremos mostrarte algunos programas simples que utilizan listas.
El primero de ellos intenta encontrar el valor mayor en la lista. Mira el código en el editor.
Console
El concepto es bastante simple - asumimos temporalmente que el primer elemento es el más
grande y comparamos la hipótesis con todos los elementos restantes de la lista.
El código puede ser reescrito para hacer uso de la forma recién introducida del bucle
for :
Nota:
Nota:
LAB
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.
1 my_list = [1, 2, 4, 4, 1, 4, 2, 6, 2, 9]
2 #
3 # Escribe tu código aquí.
4 #
5 print("La lista con elementos únicos:")
6 print(my_list)
7
8
Console
3.6.7 RESUMEN DE SECCIÓN
1. Si tienes una lista list_1 , y la siguiente asignación: list_2 = list_1 esto no hace una
copia de la lista list_1 , pero hace que las variables list_1 y list_2 apunten a la
misma lista en la memoria. Por ejemplo:
2. Si deseas copiar una lista o parte de la lista, puedes hacerlo haciendo uso de
rebanadas:
4. Los parámetros start y end son opcionales al partir en rebanadas una lista:
list[start:end] , por ejemplo:
1 my_list = [1, 2, 3, 4, 5]
2 slice_one = my_list[2: ]
3 slice_two = my_list[ :2]
4 slice_three = my_list[-2: ]
5
6 print(slice_one) # output: [3, 4, 5]
7 print(slice_two) # output: [1, 2]
8 print(slice_three) # output: [4, 5]
9
1 my_list = [1, 2, 3, 4, 5]
2 del my_list[0:2]
3 print(my_list) # output: [3, 4, 5]
4
5 del my_list[:]
6 print(my_list) # elimina el contenido de la lista, genera: []
7
6. Puedes probar si algunos elementos existen en una lista o no utilizando las palabras
clave in y not in , por ejemplo:
Revisar
Revisar
Revisar
Pregunta 5: Inserta in o not in en lugar de ??? para que el código genere el resultado
esperado.
Revisar
3.7 Sección 7 – Listas en
aplicaciones avanzadas
En esta sección aprenderás sobre arreglos, listas anidadas (matrices) y listas por
comprensión.
3.7.1 Listas dentro de listas
Las listas pueden constar de escalares (es decir, números) y elementos de una
estructura mucho más compleja (ya has visto ejemplos como cadenas, booleanos o
incluso otras listas en las lecciones del Resumen de la Sección anterior). Veamos más de
cerca el caso en el que los elementos de una lista son listas.
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.
1 row = []
2
3 for i in range(8):
4 row.append(WHITE_PAWN)
5
Crea una lista que contiene ocho elementos que representan la segunda fila del tablero
de ajedrez: la que está llena de peones (supon que WHITE_PAWN es un símbolo
predefinido que representa un peón blanco).
Comprensión de lista
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 la rellena con cuadrados de
diez números enteros que comienzan desde cero (0, 1, 4, 9, 16, 25, 36, 49, 64, 81)
Ejemplo #2:
1 twos = [2 ** i for i in range(8)]
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 crea una lista con solo los elementos impares de la lista squares .
Entonces, si queremos crear una lista de listas que representan todo el tablero de
ajedrez, se puede hacer de la siguiente manera:
1 board = []
2
3 for i in range(8):
4 row = [EMPTY for i in range(8)]
5 board.append(row)
6
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 board ;
la parte exterior se repite ocho veces;
en total, la lista board 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.
1 board[0][0] = ROOK
2 board[0][7] = ROOK
3 board[7][0] = ROOK
4 board[7][7] = ROOK
5
1 board[4][2] = KNIGHT
2
1 board[3][4] = PAWN
2
Console
3.7.3 Naturaleza multidimensional de las
listas: aplicaciones avanzadas
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.
Ahora encuentra la temperatura más alta durante todo el mes - analiza el código:
Note:
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:
1 rooms[1][9][13] = True
2
1 rooms[0][4][1] = False
2
1 vacancy = 0
2
3 for room_number in range(20):
4 if not rooms[2][14][room_number]:
5 vacancy += 1
6
La variable vacancy 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!
2. Puedes usar listas anidadas en Python para crear matrices (es decir, listas
bidimensionales). Por ejemplo:
1 # Una tabla de cuatro columnas y cuatro filas: un arreglo bidimensional (4x4)
2
3 table = [[":(", ":)", ":(", ":)"],
4 [":)", ":(", ":)", ":)"],
5 [":(", ":)", ":)", ":("],
6 [":)", ":)", ":)", ":("]]
7
8 print(table)
9 print(table[0][0]) # output: ':('
10 print(table[0][3]) # output: ':)'
11
3. Puedes anidar tantas listas en las listas como desee y, por lo tanto, crear listas n-
dimensionales, por ejemplo, arreglos de tres, cuatro o incluso sesenta y cuatro
dimensiones. Por ejemplo:
PRUEBA MÓDULO 3
¡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, que te ayudará a evaluar lo que has
aprendido hasta ahora.
La siguiente prueba se basa en lo que acabas de aprender. Hay veinte preguntas en total
y debes obtener al menos un 70% para aprobar.
¡Buena suerte!
Pregunta 1
Un operador que puede verificar si dos valores son iguales se codifica como:
==
=
===
!=
Pregunta 2
El valor asignado finalmente a x es igual a:
1 x = 1
2 x = x == x
3
True
False
1
Pregunta 3
¿Cuántos ( * ) enviará el siguiente fragmento de código a la consola?
1 i = 0
2 while i <= 3 :
3 i += 2
4 print("*")
5
2
Pregunta 4
¿Cuántos ( * ) enviará el siguiente fragmento de código a la consola?
1 i = 0
2 while i <= 5 :
3 i += 1
4 if i % 2 == 0:
5 break
6 print("*")
7
1
Pregunta 5
¿Cuántos ( # ) enviará el siguiente fragmento de código a la consola?
1 for i in range(1):
2 print("#")
3 else:
4 print("#")
5
0
Pregunta 6
¿Cuántos ( # ) enviará el siguiente fragmento de código a la consola?
1 var = 0
2 while var < 6:
3 var += 1
4 if var % 2 == 0:
5 continue
6 print("#")
7
3
0
Pregunta 7
¿Cuántos ( # ) enviará el siguiente fragmento de código a la consola?
1 var = 1
2 while var < 10:
3 print("#")
4 var = var << 1
5
4
2
8
Pregunta 8
¿Qué valor será asignado a la variable x ?
1 z = 10
2 y = 0
3 x = y < z and z > y or y > z and z < y
4
True
False
0
Pregunta 9
¿Cuál es la output del siguiente fragmento de código?
1 a = 1
2 b = 0
3 c = a & b
4 d = a | b
5 e = a ^ b
6
7 print(c + d + e)
8
2
Pregunta 10
¿Cuál es la output del siguiente fragmento de código?
1
-2
-1
Pregunta 11
¿Cuál es la output del siguiente fragmento de código?
1 my_list = [1, 2, 3, 4]
2 print(my_list[-3:-2])
3
[2]
[]
[2, 3]
[2, 3, 4]
Pregunta 12
La segunda asignación:
1 vals = [0, 1, 2]
2 vals[0], vals[2] = vals[2], vals[0]
3
invierte la lista
acorta la lista
extiende la lista
1 vals = [0, 1, 2]
2 vals.insert(0, 1)
3 del vals[1]
4
4
Pregunta 14
Observa el código, y selecciona las sentencias verdaderas: (Selecciona dos
respuestas)
1 nums = [1, 2, 3]
2 vals = nums
3 del vals[1:2]
4
Pregunta 15
¿Cuáles de los siguientes enunciados son verdaderos? (Selecciona dos respuestas)
1 nums = [1, 2, 3]
2 vals = nums[-1:-2]
3
nums es más larga que vals
Pregunta 16
¿Cuál es la output del siguiente fragmento de código?
1 my_list_1 = [1, 2, 3]
2 my_list_2 = []
3 for v in my_list_1:
4 my_list_2.insert(0, v)
5 print(my_list_2)
6
[3, 2, 1]
[1, 2, 3]
[1, 1, 1]
[3, 3, 3]
Pregunta 17
¿Cuál es la output del siguiente fragmento de código?
1 my_list = [1, 2, 3]
2 for v in range(len(my_list)):
3 my_list.insert(1, my_list[v])
4 print(my_list)
5
[1, 1, 1, 1, 2, 3]
[1, 2, 3, 3, 2, 1]
[1, 2, 3, 1, 2, 3]
[3, 2, 1, 1, 2, 3]
Pregunta 18
¿Cuántos elementos contiene la lista my_list ?
3
Pregunta 19
¿Cuál es la output del siguiente fragmento de código?
6
Pregunta 20
¿Cuál es la output del siguiente fragmento de código?
Reiniciar
Evaluación de Revisión
85%
Has obtenido 85%.