Heim >Backend-Entwicklung >Python-Tutorial >Wie kann ich eine binäre Suche in Python effizient implementieren, um das Vorhandensein von Elementen zu überprüfen?

Wie kann ich eine binäre Suche in Python effizient implementieren, um das Vorhandensein von Elementen zu überprüfen?

Barbara Streisand
Barbara StreisandOriginal
2024-11-24 07:48:14220Durchsuche

How Can I Efficiently Implement a Binary Search in Python to Check for Item Existence?

Binä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!

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