Heim >Backend-Entwicklung >Python-Tutorial >Wie können wir den Schnittpunkt zweier Listen in Python effizient finden?
Überschneidende Listen: Überlappende Elemente erfassen
In diesem Programmierrätsel suchen wir nach einer Lösung, um den Schnittpunkt zweier Listen zu bestimmen und das Gemeinsame zu identifizieren Elemente zwischen ihnen. Bei zwei Listen „a“ und „b“ besteht die Aufgabe darin, die Liste zu finden, die nur die von beiden Listen gemeinsam genutzten Elemente enthält.
Problemstellung: Boolesche UND-Operation für Listen
Bedenken Sie den folgenden Codeausschnitt:
a = [1,2,3,4,5] b = [1,3,5,6] c = a and b print c
Beim Ausführen dieses Codes kann man mit einer Ausgabe von rechnen „[1,3,5]“ als Schnittpunkt der Listen „a“ und „b“. Die tatsächliche Ausgabe ist jedoch „[1,3,5,6]“, was Elemente enthält, die nicht in der Schnittmenge vorhanden sind.
Lösung: Verwendung von Set Intersection
Um eine boolesche UND-Operation (Listenschnittpunkt) für die beiden Listen durchzuführen, Duplikate zu vermeiden und die Reihenfolge aufrechtzuerhalten, können wir den Satzschnittpunkt nutzen. Mengen sind ungeordnete Sammlungen einzigartiger Elemente. Indem wir die Listen in Mengen umwandeln, ihren Schnittpunkt nehmen und die resultierende Menge wieder in eine Liste umwandeln, können wir das gewünschte Ergebnis erhalten:
>>> a = [1,2,3,4,5] >>> b = [1,3,5,6] >>> list(set(a) & set(b)) [1, 3, 5]
Diese Lösung identifiziert effizient nur die Elemente, die zu beiden gehören, und gibt sie zurück Listen, die eine prägnante Darstellung ihrer Schnittmenge liefern.
Das obige ist der detaillierte Inhalt vonWie können wir den Schnittpunkt zweier Listen in Python effizient finden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!