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!