


Wie kann ich eine binäre Suche in Python effizient implementieren, um das Vorhandensein von Elementen zu überprüfen?
Nov 24, 2024 am 07:48 AMBinäre Suche (Halo-Suche) in Python
Python bietet Bibliotheksfunktionen zur Implementierung der binären Suche (auch binäre Suche genannt). Wird zum Suchen verwendet Elemente in einer sortierten Liste oder einem Tupel. Diese Funktionen geben jedoch weiterhin eine Position zurück, wenn das Element nicht gefunden wird.
Um dieses Problem zu lösen und nur zu erkennen, ob das Element vorhanden ist, besteht eine Möglichkeit darin, die Funktion bisect.bisect_left() zu verwenden, um die Einfügeposition zu finden und dann zu prüfen, ob das Element an dieser Position mit dem Zielelement übereinstimmt . Dies kann jedoch mühsam sein und erfordert außerdem eine Überprüfung der Grenzen, wenn die Zahl größer als die größte Zahl in der Liste ist.
Aufgrund des Speicherverbrauchs wird in der Frage alternativ ein Wörterbuch vorgeschlagen. Dies kann jedoch etwa den doppelten Speicherbedarf erfordern.
Daher kann dieses Problem durch die Implementierung einer binären Suche mit benutzerdefiniertem Code gelöst werden:
from bisect import bisect_left def binary_search(a, x, lo=0, hi=None): if hi is None: hi = len(a) pos = bisect_left(a, x, lo, hi) # find insertion position return pos if pos != hi and a[pos] == x else -1 # don't walk off the end
Diese Funktion verwendet die Funktion bisect_left(), um die Einfügeposition zu finden, die die Position von angibt das Zielelement, falls es vorhanden ist, oder eine Position angeben, die außerhalb des Bereichs liegt, wenn es nicht vorhanden ist. Sie können feststellen, ob das Zielelement vorhanden ist, indem Sie prüfen, ob das Element an dieser Position mit dem Zielelement übereinstimmt.
Das obige ist der detaillierte Inhalt vonWie kann ich eine binäre Suche in Python effizient implementieren, um das Vorhandensein von Elementen zu überprüfen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heißer Artikel

Hot-Tools-Tags

Heißer Artikel

Heiße Artikel -Tags

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Wie benutze ich eine schöne Suppe, um HTML zu analysieren?

So herunterladen Sie Dateien in Python

So verwenden Sie Python, um die ZiPF -Verteilung einer Textdatei zu finden

Wie man mit PDF -Dokumenten mit Python arbeitet

Wie kann man mit Redis in Django -Anwendungen zwischenstrichen

Wie führe ich ein tiefes Lernen mit Tensorflow oder Pytorch durch?

So implementieren Sie Ihre eigene Datenstruktur in Python
