tuple()
Aunque no tiene mucha utilidad. ¿Por qué?
a = ()
b = tuple()
print(a)
print(b)
a = (1,2,3,4)
b = tuple(['a', 1, True, [1, 2]])
print(a)
print(b)
c = tuple([1, 2, 3, 4])
d = tuple((1, 2, 3, 4))
print(c)
print(d)
La función tuple(iterable)
convierte a tupla el tipo de dato dado por la variable iterable
. Cada elemento de iterable
es agregado a una tupla.
tup = tuple("abc")
print(tup)
Los valores individuales de una tupla pueden ser recuperados asignando la tupla a las variables respectivas. Esto se llama desempaquetar la tupla.
tupla = (1, 2, 3)
a, b, c = tupla
print(tupla)
print(a, b, c)
Para desempaquetar correctamente debe utilizar tantas variables como elementos posee la tupla.
tupla = (1, 2, 3)
a, b = tupla
Además, también es posible extraer los valores usando su índice, al igual que con las listas:
tupla = (1, 2, 3)
print(tupla[1])
A diferencia de las listas, los elementos de una tupla no se pueden modificar:
tupla = (1, 2, 3)
tupla[0] = 100
Las tuplas se usan siempre que es necesario agrupar valores. Generalmente, conceptos del mundo real son representados como tuplas que agrupan información sobre ellos.
posicion_alfil = (7, 6)
alumno = ('Fulano', 'De Tal', '201199001-1')
carta = (5, 'corazones')
fecha = (2011, 4, 12)
triangulo = ((5, 1), (2, 4), (-2, 0))
personaje = ('Arturo Prat', (1848, 4, 3),
(1879, 5, 21))
punto = (6.6, -2.4, 3.7)
x, y, z = punto
print(x)
personaje = ("Bernardo O'Higgins", (1778, 8, 20), (1842, 10, 24))
nombre, nacimiento, defuncion = personaje
an, mn, dn = nacimiento
ad, md, dd = defuncion
print(ad - an)
Dos tuplas son iguales cuando tienen el mismo tamaño y cada uno de sus elementos correspondientes tienen el mismo valor:
(1, 2) == (3 // 2, 1 + 1)
(6, 1) == (6, 2)
(6, 1) == (6, 1, 0)
Para determinar si una tupla es menor que otra, se utiliza lo que se denomina orden lexicográfico. Si los elementos en la primera posición de ambas tuplas son distintos, ellos determinan el ordenamiento de las tuplas:
(1, 4, 7) < (2, 0, 0, 1)
(1, 9, 10) < (0, 5)
La primera comparación es True porque 1 < 2
. La segunda comparación es False porque 1 > 0
. No importa el valor que tengan los siguientes valores, o si una tupla tiene más elementos que la otra.
Si los elementos en la primera posición son iguales, entonces se usa el valor siguiente para hacer la comparación:
(6, 1, 8) < (6, 2, 8)
(6, 1, 8) < (6, 0)
La primera comparación es True porque 6 == 6
y 1 < 2
. La segunda comparación es False porque 6 == 6
y 1 > 0
.
Si los elementos respectivos siguen siendo iguales, entonces se sigue probando con los siguientes uno por uno, hasta encontrar dos distintos. Si a una tupla se le acaban los elementos para comparar antes que a la otra, entonces es considerada menor que la otra:
(1, 2) < (1, 2, 4)
(1, 3) < (1, 2, 4)
La primera compación es True
porque 1 == 1
, 2 == 2
, y ahí se acaban los elementos de la primera tupla. La segunda comparación es False porque 1 == 1
y 3 < 2
; en este caso sí se alcanza a determinar el resultado antes que se acaben los elementos de la primera tupla.
La instrucción in
permite verificar si un elemento está contenido en una tupla.
t = (1, 5, 6)
1 in t
3 not in t
La función len(tupla)
entrega la cantidad de elementos de la tupla ingresada como parámetro.
t = (1,2,3,4,8,10)
print("La cantidad de elementos en la tupla es", len(t))
Usando la función sum(tupla)
, se puede determinar la suma de los elementos de una tupla.
sum(t)
La función min(tupla)
y max(tupla)
entrega el valor mínimo y máximo de la tupla
ingresada como parámetro.
print(min(t), max(t))
for
en tuplas¶for
puede ser usado para iterar sobre tuplas.tt = tuple(range(10))
for e in tt:
print(e)
range
Algunas veces es necesario integrar varias estructuras para resolver ciertos problemas.
# Opcion 1
ramos = [
('Progra', 'IWI-131', 3),
('Mate', 'MAT-021', 5),
('Física', 'FIS-100', 3),
('Ed.Fisica', 'DEW-100', 1),
('Inmanente', 'HRW-102', 2)
]
# Iterar sobre la lista de tuplas
for ramo in ramos:
nombre, sigla, c = ramo
print(nombre, 'tiene', c, 'creditos')
# Opcion 2
ramos = [
('Progra', 'IWI-131', 3),
('Mate', 'MAT-021', 5),
('Física', 'FIS-100', 3),
('Ed.Fisica', 'DEW-100', 1),
('Inmanente', 'HRW-102', 2)
]
# Iterar sobre la lista de tuplas
for nombre, sigla, c in ramos:
print(nombre, 'tiene', c, 'creditos')
star_wars = [
(4, 'Una nueva Esperanza'),
(5, 'El Imperio Contraataca'),
(6, 'El Retorno del Jedi'),
(1, 'La Amenaza Fantasma'),
(2, 'El Ataque de los Clones'),
(3, 'La Venganza de los Siths'),
(7, 'El Despertar de la Fuerza'),
(8, 'Los Ultimos Jedi')
]
star_wars
star_wars.sort()
star_wars
nums = [(1, 4), (1, 2), (1, 1), (1, 10)]
nums
nums.sort()
nums
Para ordenar una lista de tuplas, utiliza el criterio de comparación de tuplas utilizando un orden ascendente.
1. Escriba una función distancia(p1, p2)
que retorne la distancia entre los puntos p1
y p2
:
>>> a = (5.1, 7.3, 2.4)
>>> b = (1.1, 2.8, 4.9)
>>> distancia(a, b)
6.5192024052026492
def distancia(p1, p2):
x1, y1, z1 = p1
x2, y2, z2 = p2
dx = x2 - x1
dy = y2 - y1
dz = z2 - z1
return (dx ** 2 + dy ** 2 + dz ** 2) ** 0.5
a = (5.1, 7.3, 2.4)
b = (1.1, 2.8, 4.9)
distancia(a, b)
2. Un polígono está determinado por la lista de sus vértices. Escriba una función perimetro(vertices)
que entregue el perímetro del polígono definido por la lista vertices:
>>> p = [(4, 1), (7, 2), (7, 4), (5, 9)]
>>> perimetro(p)
18.609700215601432
# Distancia para puntos en R^2
def distancia(p1, p2):
(x1, y1), (x2, y2) = p1, p2
dx, dy = x2 - x1, y2 - y1
return (dx ** 2 + dy ** 2) ** .5
# Propuesta 1
def perimetro(vertices):
n = len(vertices)
suma = 0.0
for i in range(n):
a = vertices[i]
b = vertices[(i + 1) % n]
suma += distancia(a, b)
return suma
p = [(4, 1), (7, 2), (7, 4), (5, 9)]
perimetro(p)
# Propuesta 2
def perimetro(vertices):
n = len(vertices)
actual = vertices[0:n]
sgte = vertices[1:n] + [vertices[0]]
distancias = []
for i in range(n):
d = distancia(actual[i], sgte[i])
distancias.append(d)
return sum(distancias)
p = [(4, 1), (7, 2), (7, 4), (5, 9)]
perimetro(p)