Python: maximiza las tuplas anidadas

A veces, mientras trabajamos con registros, podemos tener un problema en el que necesitamos realizar un índice máximo de elementos de tupla. Esto puede complicarse con los elementos de tupla para que sean tupla y los elementos internos vuelvan a ser tupla. Analicemos ciertas formas en que se puede resolver este problema.

Método n.º 1: uso de zip() + max()la expresión del generador anidado +
La combinación de las funciones anteriores se puede usar para realizar la tarea. En esto, combinamos los elementos a través de tuplas usando zip(). Las iteraciones y la lógica de maximización las proporciona la expresión del generador.

# Python3 code to demonstrate working of
# Maximizing Nested Tuples
# using zip() + nested generator expression + max()
  
# initialize tuples
test_tup1 = ((1, 3), (4, 5), (2, 9), (1, 10))
test_tup2 = ((6, 7), (3, 9), (1, 1), (7, 3))
  
# printing original tuples
print("The original tuple 1 : " + str(test_tup1))
print("The original tuple 2 : " + str(test_tup2))
  
# Maximizing Nested Tuples
# using zip() + nested generator expression + max()
res = tuple(tuple(max(a, b) for a, b in zip(tup1, tup2))\
    for tup1, tup2 in zip(test_tup1, test_tup2))
  
# printing result
print("The resultant tuple after maximization : " + str(res))
Producción :

The original tuple 1 : ((1, 3), (4, 5), (2, 9), (1, 10))
The original tuple 2 : ((6, 7), (3, 9), (1, 1), (7, 3))
The resultant tuple after maximization : ((6, 7), (4, 9), (2, 9), (7, 10))

Método n.º 2: uso de isinstance() + zip() + max() + bucle + comprensión de lista
La combinación de las funciones anteriores se puede utilizar para realizar esta tarea en particular. En esto, verificamos el tipo de anidamiento y realizamos la recursividad. Este método puede dar flexibilidad de anidamiento de más de 1 nivel.

# Python3 code to demonstrate working of
# Maximizing Nested Tuples
# using isinstance() + zip() + loop + list comprehension + max()
  
# function to perform task 
def tup_max(tup1, tup2):
    if isinstance(tup1, (list, tuple)) and isinstance(tup2, (list, tuple)):
        return tuple(tup_max(x, y) for x, y in zip(tup1, tup2))
    return max(tup1, tup2)
  
# initialize tuples
test_tup1 = ((1, 3), (4, 5), (2, 9), (1, 10))
test_tup2 = ((6, 7), (3, 9), (1, 1), (7, 3))
  
# printing original tuples
print("The original tuple 1 : " + str(test_tup1))
print("The original tuple 2 : " + str(test_tup2))
  
# Maximizing Nested Tuples
# using isinstance() + zip() + loop + list comprehension + max()
res = tuple(tup_max(x, y) for x, y in zip(test_tup1, test_tup2))
  
# printing result
print("The resultant tuple after maximization : " + str(res))
Producción :

The original tuple 1 : ((1, 3), (4, 5), (2, 9), (1, 10))
The original tuple 2 : ((6, 7), (3, 9), (1, 1), (7, 3))
The resultant tuple after maximization : ((6, 7), (4, 9), (2, 9), (7, 10))

Publicación traducida automáticamente

Artículo escrito por manjeet_04 y traducido por Barcelona Geeks. The original can be accessed here. Licence: CCBY-SA

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *