Nehmen wir an, wir haben zwei Listen
list1 = [1, 3, 5, 7, 9]
list2 = [1, 2, 3, 4, 5]
Aus den beiden obigen Listen geht hervor, dass die Positionen 1, 3, 5 in Liste2 vorhanden sind, die Positionen 7, 9 jedoch nicht. Andererseits sind die Einträge 1, 3, 5 in Liste 1 vorhanden und die Einträge 2, 4 nicht.
Was ist die beste Lösung, um eine neue Liste mit den Elementen 7, 9 und 2, 4 zurückzugeben?
Alle obigen Antworten führen zur Lösung, was ist nun das Optimum?
def difference(list1, list2):
new_list = []
for i in list1:
if i not in list2:
new_list.append(i)
for j in list2:
if j not in list1:
new_list.append(j)
return new_list
gegen
def sym_diff(list1, list2):
return list(set(list1).symmetric_difference(set(list2)))
Mit timeit können wir die Ergebnisse sehen
t1 = timeit.Timer("difference(list1, list2)", "from __main__ import difference,
list1, list2")
t2 = timeit.Timer("sym_diff(list1, list2)", "from __main__ import sym_diff,
list1, list2")
print('Using two for loops', t1.timeit(number=100000), 'Milliseconds')
print('Using two for loops', t2.timeit(number=100000), 'Milliseconds')
gibt zurück.
[7, 9, 2, 4]
Using two for loops 0.11572412995155901 Milliseconds
Using symmetric_difference 0.11285737506113946 Milliseconds
Process finished with exit code 0