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?

Nov 24, 2024 am 07:48 AM

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
Nach dem Login kopieren

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!

Erklärung dieser Website
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

Heiße Artikel -Tags

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Wie benutze ich eine schöne Suppe, um HTML zu analysieren? Wie benutze ich eine schöne Suppe, um HTML zu analysieren? Mar 10, 2025 pm 06:54 PM

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

Bildfilterung in Python Bildfilterung in Python Mar 03, 2025 am 09:44 AM

Bildfilterung in Python

So herunterladen Sie Dateien in Python So herunterladen Sie Dateien in Python Mar 01, 2025 am 10:03 AM

So herunterladen Sie Dateien in Python

So verwenden Sie Python, um die ZiPF -Verteilung einer Textdatei zu finden So verwenden Sie Python, um die ZiPF -Verteilung einer Textdatei zu finden Mar 05, 2025 am 09:58 AM

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

Wie man mit PDF -Dokumenten mit Python arbeitet Wie man mit PDF -Dokumenten mit Python arbeitet Mar 02, 2025 am 09:54 AM

Wie man mit PDF -Dokumenten mit Python arbeitet

Wie kann man mit Redis in Django -Anwendungen zwischenstrichen Wie kann man mit Redis in Django -Anwendungen zwischenstrichen Mar 02, 2025 am 10:10 AM

Wie kann man mit Redis in Django -Anwendungen zwischenstrichen

Wie führe ich ein tiefes Lernen mit Tensorflow oder Pytorch durch? Wie führe ich ein tiefes Lernen mit Tensorflow oder Pytorch durch? Mar 10, 2025 pm 06:52 PM

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

So implementieren Sie Ihre eigene Datenstruktur in Python So implementieren Sie Ihre eigene Datenstruktur in Python Mar 03, 2025 am 09:28 AM

So implementieren Sie Ihre eigene Datenstruktur in Python

See all articles