Programa de Python para eliminar el índice de elementos duplicados de otra lista – Part 1

Dadas dos listas, la tarea es escribir un programa de Python para eliminar todos los elementos de índice de la segunda lista que son índices de elementos duplicados de la primera lista.

Ejemplos:

Entrada : test_list1 = [3, 5, 6, 5, 3, 7, 8, 6], test_list2 = [1, 7, 6, 3, 7, 9, 10, 11] Salida: [1, 7, 
6 , 9, 10] 
Explicación : 3, 7 y 11 corresponden a la segunda aparición de 5, 3 y 6, por lo que se eliminaron.

Entrada : test_list1 = [3, 5, 6, 5, 3, 7, 8], test_list2 = [1, 7, 6, 3, 7, 9, 10] Salida: [1, 7, 6, 9, 
10
Explicación : 3 y 7 corresponden a la segunda aparición de 5 y 3, por lo tanto, se eliminan. 
 

Método 1: Usar lista de comprensión + bucle + enumerar()

En esto, realizamos la tarea de obtener todos los índices usando enumerate() y bucle usando set para almacenar elementos ya ocurridos. Luego, se omiten los mismos índices de otra lista.

Python3

# Python3 code to demonstrate working of
# Remove duplicate elements index from other list
# Using list comprehension + loop + enumerate()
  
# initializing lists
test_list1 = [3, 5, 6, 5, 3, 7, 8, 6]
test_list2 = [1, 7, 6, 3, 7, 9, 10, 11]
               
# printing original lists
print("The original list 1 is : " + str(test_list1))
print("The original list 2 is : " + str(test_list2))
  
oc_set = set() 
temp = [] 
  
# getting duplicate elements list
for idx, val in enumerate(test_list1): 
    if val not in oc_set: 
        oc_set.add(val)          
    else: 
        temp.append(idx)
  
# excluding duplicate indices from other list
res = [ele for idx, ele in enumerate(test_list2) if idx not in temp]
  
# printing result
print("The list after removing duplicate indices : " + str(res))

 Producción:

The original list 1 is : [3, 5, 6, 5, 3, 7, 8, 6]
The original list 2 is : [1, 7, 6, 3, 7, 9, 10, 11]
The list after removing duplicate indices : [1, 7, 6, 9, 10]

 Método 2: usar la lista de comprensión + enumerar()

En esto, realizamos una tarea similar a la anterior solo de manera abreviada, extrayendo índices usando enumerate() y comprensión de listas.

Python3

# Python3 code to demonstrate working of
# Remove duplicate elements index from other list
# Using list comprehension + enumerate()
  
# initializing lists
test_list1 = [3, 5, 6, 5, 3, 7, 8, 6]
test_list2 = [1, 7, 6, 3, 7, 9, 10, 11]
               
# printing original lists
print("The original list 1 is : " + str(test_list1))
print("The original list 2 is : " + str(test_list2))
  
# getting duplicate elements list using list comprehension
temp = [idx for idx, val in enumerate(test_list1) if val in test_list1[:idx]]
  
# excluding duplicate indices from other list
res = [ele for idx, ele in enumerate(test_list2) if idx not in temp]
  
# printing result
print("The list after removing duplicate indices : " + str(res))

Producción:

The original list 1 is : [3, 5, 6, 5, 3, 7, 8, 6]
The original list 2 is : [1, 7, 6, 3, 7, 9, 10, 11]
The list after removing duplicate indices : [1, 7, 6, 9, 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 *