Heim >Backend-Entwicklung >Python-Tutorial >Wie können wir eine Liste basierend auf einem bedingten Filter effizient partitionieren?

Wie können wir eine Liste basierend auf einem bedingten Filter effizient partitionieren?

Patricia Arquette
Patricia ArquetteOriginal
2024-12-03 15:58:15598Durchsuche

How Can We Efficiently Partition a List Based on a Conditional Filter?

Effiziente Listenpartitionierung basierend auf bedingter Filterung

Bedenken Sie die Notwendigkeit, eine Liste basierend auf einer Bedingung in zwei Unterlisten aufzuteilen. Ein naiver Ansatz würde bedeuten, die Liste zweimal zu durchlaufen, einmal für jede Unterliste. Auf der Suche nach einer effizienten und eleganten Alternative prüfen wir mehrere Optionen.

Ein Ansatz besteht darin, die Liste manuell zu durchlaufen und jedes Element basierend auf der Bedingungsprüfung dynamisch an die entsprechende Unterliste anzuhängen. Dies wird im folgenden Code demonstriert:

good, bad = [], []
for x in mylist:
    (bad, good)[x in goodvals].append(x)

In diesem Code wird der Ausdruck (schlecht, gut) abhängig vom booleschen Wert von x in guten Werten entweder als schlecht oder gut ausgewertet. Anschließend wird die append()-Methode der ausgewählten Unterliste aufgerufen, um das aktuelle Element hinzuzufügen.

Durch die Eliminierung der Notwendigkeit mehrerer Iterationen und die Verwendung prägnanter Listenverständnisse bietet dieser Ansatz sowohl Leistungs- als auch Codelesbarkeitsvorteile gegenüber den beiden Iterationsimplementierung.

Das obige ist der detaillierte Inhalt vonWie können wir eine Liste basierend auf einem bedingten Filter effizient partitionieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn