Heim Backend-Entwicklung Python-Tutorial Eine kurze Diskussion über Wörterbücher und Hash-Tabellen in Python und die Lösung von Hash-Konflikten

Eine kurze Diskussion über Wörterbücher und Hash-Tabellen in Python und die Lösung von Hash-Konflikten

Oct 09, 2018 pm 02:47 PM
python

Der Inhalt dieses Artikels ist eine kurze Diskussion über Wörterbücher und Hash-Tabellen in Python und die Lösung von Hash-Konflikten. Ich hoffe, dass er für Sie hilfreich ist.

Python verwendet Hash-Tabellen, um Diktate zu implementieren.

Eine Hash-Tabelle ist eigentlich ein Sparse-Array (ein Array, das immer leere Elemente enthält, wird als Sparse-Array bezeichnet). In allgemeinen Büchern werden die Einheiten in einer Hash-Tabelle normalerweise als Buckets bezeichnet. existieren dict In der Hash-Tabelle belegt jedes Schlüssel-Wert-Paar ein Tabellenelement, und jedes Tabellenelement besteht aus zwei Teilen, einem ist ein Verweis auf den Schlüssel und der andere ist ein Verweis auf den Wert. Da jede Tabellenzelle die gleiche Größe hat, können Sie eine Tabellenzelle anhand des Offsets lesen.

Python wird versuchen sicherzustellen, dass etwa ein Drittel der Tabellenelemente leer sind. Wenn dieser Schwellenwert fast erreicht ist, wird die ursprüngliche Hash-Tabelle erweitert und in eine größere Hash-Tabelle kopiert.

Wenn Sie ein Objekt in eine Hash-Tabelle einfügen möchten, müssen Sie zunächst den Hash-Wert des Elementschlüssels berechnen. Dies erfordert, dass der Schlüssel hashbar sein muss.

Ein hashbares Objekt muss die folgenden Bedingungen erfüllen:

Unterstützt die Funktion hash() und der von der Methode __hash__() erhaltene Hashwert bleibt unverändert.

Unterstützt die Gleichheitserkennung durch die Methode __eq__().

Wenn a == b wahr ist, dann ist hash(a) == hash(b) auch wahr.

Im Folgenden wird hauptsächlich der Hash-Tabellenalgorithmus erläutert.

Um den Schlüssel zu bekommen Der Wert search_value entspricht search_key. Python ruft zur Berechnung zunächst hash(search_key) auf Suchschlüssel Der Hash-Wert des Werts, die niedrigsten Ziffern dieses Werts werden als Offsets verwendet und das Tabellenelement wird in der Hash-Tabelle durchsucht (die spezifische Zahl hängt von der Größe der aktuellen Hash-Tabelle ab). Wenn das gefundene Tabellenelement leer ist, wird KeyError geworfen Ausnahme; wenn es nicht leer ist, gibt es ein Paar „found_key:found_value“ im Tabellenelement, überprüfen Sie „search_key“ und „found_key“. Ob sie gleich sind. Wenn ja, wird „found_value“ zurückgegeben. Wenn sie nicht gleich sind, spricht man von einer Hash-Kollision.

Um den Hash-Konflikt zu lösen, nimmt der Algorithmus noch ein paar Bits im Hash-Wert, verarbeitet ihn dann mit einer speziellen Methode und verwendet den erhaltenen neuen Wert als Offset für die Suche Das Hash-Tabellenelement: Wenn das gefundene Tabellenelement leer ist, wird auch eine KeyError-Ausnahme ausgelöst, wenn es nicht leer ist. Vergleichen Sie die Schlüssel, um festzustellen, ob sie konsistent sind, und geben Sie den entsprechenden Wert zurück, wenn sie konsistent sind Wenn erneut ein Hash-Konflikt gefunden wird, wiederholen Sie die obigen Schritte.

Der Vorgang zum Hinzufügen eines neuen Elements ist fast der gleiche wie oben, mit der Ausnahme, dass das neue Element eingefügt wird, wenn ein leeres Tabellenelement gefunden wird. Wenn es nicht leer ist, wird der Hash wiederholt und Die Suche wird fortgesetzt.

Gehen Sie dorthin Wenn dem Diktat ein neues Element hinzugefügt wird und ein Hash-Konflikt auftritt, kann das neue Element so angeordnet werden, dass es an einem anderen Ort gespeichert wird. Es wird also die folgende Situation eintreten: dict([key1, value1], [key2, value2]) und dict([key2, value2], [key1, value1]) Beim Vergleich sind zwei Wörterbücher gleich, aber wenn die Hashes von Schlüssel1 und Schlüssel2 in Konflikt geraten, ist die Reihenfolge der beiden Schlüssel im Wörterbuch unterschiedlich.

Wann immer, geh Fügen Sie neue Schlüssel zu dict, Python hinzu Der Parser kann entscheiden, das Wörterbuch zu erweitern. Das Ergebnis der Erweiterung besteht darin, eine größere Hash-Tabelle zu erstellen und vorhandene Elemente im Wörterbuch zur neuen Hash-Tabelle hinzuzufügen. Während dieses Vorgangs können neue Hash-Konflikte auftreten, die dazu führen, dass sich die Reihenfolge der Schlüssel in der neuen Hash-Tabelle ändert. Was passiert, wenn Sie ein Wörterbuch durchlaufen und ihm gleichzeitig neue Schlüssel hinzufügen? Leider wurde die Kapazität erweitert, leider hat sich die Reihenfolge der Tasten geändert orz.

Da die Hash-Tabelle spärlich sein muss, muss ihr Platzverbrauch viel größer sein. Dies ist ein typischer Kompromiss zwischen Platz und Zeit.

Das obige ist der detaillierte Inhalt vonEine kurze Diskussion über Wörterbücher und Hash-Tabellen in Python und die Lösung von Hash-Konflikten. 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 KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

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)

Was ist die Funktion der C -Sprachsumme? Was ist die Funktion der C -Sprachsumme? Apr 03, 2025 pm 02:21 PM

Es gibt keine integrierte Summenfunktion in der C-Sprache, daher muss sie selbst geschrieben werden. Die Summe kann erreicht werden, indem das Array durchquert und Elemente akkumulieren: Schleifenversion: Die Summe wird für die Schleifen- und Arraylänge berechnet. Zeigerversion: Verwenden Sie Zeiger, um auf Array-Elemente zu verweisen, und eine effiziente Summierung wird durch Selbststillstandszeiger erzielt. Dynamisch Array -Array -Version zuweisen: Zuordnen Sie Arrays dynamisch und verwalten Sie selbst den Speicher selbst, um sicherzustellen, dass der zugewiesene Speicher befreit wird, um Speicherlecks zu verhindern.

Wer bekommt mehr Python oder JavaScript bezahlt? Wer bekommt mehr Python oder JavaScript bezahlt? Apr 04, 2025 am 12:09 AM

Es gibt kein absolutes Gehalt für Python- und JavaScript -Entwickler, je nach Fähigkeiten und Branchenbedürfnissen. 1. Python kann mehr in Datenwissenschaft und maschinellem Lernen bezahlt werden. 2. JavaScript hat eine große Nachfrage in der Entwicklung von Front-End- und Full-Stack-Entwicklung, und sein Gehalt ist auch beträchtlich. 3. Einflussfaktoren umfassen Erfahrung, geografische Standort, Unternehmensgröße und spezifische Fähigkeiten.

Bedarf die Produktion von H5 -Seiten eine kontinuierliche Wartung? Bedarf die Produktion von H5 -Seiten eine kontinuierliche Wartung? Apr 05, 2025 pm 11:27 PM

Die H5 -Seite muss aufgrund von Faktoren wie Code -Schwachstellen, Browserkompatibilität, Leistungsoptimierung, Sicherheitsaktualisierungen und Verbesserungen der Benutzererfahrung kontinuierlich aufrechterhalten werden. Zu den effektiven Wartungsmethoden gehören das Erstellen eines vollständigen Testsystems, die Verwendung von Versionstools für Versionskontrolle, die regelmäßige Überwachung der Seitenleistung, das Sammeln von Benutzern und die Formulierung von Wartungsplänen.

Ist DifferiDItistinginginging verwandt? Ist DifferiDItistinginginging verwandt? Apr 03, 2025 pm 10:30 PM

Obwohl eindeutig und unterschiedlich mit der Unterscheidung zusammenhängen, werden sie unterschiedlich verwendet: Unterschieds (Adjektiv) beschreibt die Einzigartigkeit der Dinge selbst und wird verwendet, um Unterschiede zwischen den Dingen zu betonen; Das Unterscheidungsverhalten oder die Fähigkeit des Unterschieds ist eindeutig (Verb) und wird verwendet, um den Diskriminierungsprozess zu beschreiben. In der Programmierung wird häufig unterschiedlich, um die Einzigartigkeit von Elementen in einer Sammlung darzustellen, wie z. B. Deduplizierungsoperationen; Unterscheidet spiegelt sich in der Gestaltung von Algorithmen oder Funktionen wider, wie z. B. die Unterscheidung von ungeraden und sogar Zahlen. Bei der Optimierung sollte der eindeutige Betrieb den entsprechenden Algorithmus und die Datenstruktur auswählen, während der unterschiedliche Betrieb die Unterscheidung zwischen logischer Effizienz optimieren und auf das Schreiben klarer und lesbarer Code achten sollte.

Wie versteht man! X in c? Wie versteht man! X in c? Apr 03, 2025 pm 02:33 PM

! X Understanding! X ist ein logischer Nicht-Operator in der C-Sprache. Es booleschen den Wert von x, dh wahre Änderungen zu falschen, falschen Änderungen an True. Aber seien Sie sich bewusst, dass Wahrheit und Falschheit in C eher durch numerische Werte als durch Boolesche Typen dargestellt werden, ungleich Null wird als wahr angesehen und nur 0 wird als falsch angesehen. Daher handelt es sich um negative Zahlen wie positive Zahlen und gilt als wahr.

Was bedeutet Summe in der C -Sprache? Was bedeutet Summe in der C -Sprache? Apr 03, 2025 pm 02:36 PM

Es gibt keine integrierte Summenfunktion in C für die Summe, kann jedoch implementiert werden durch: Verwenden einer Schleife, um Elemente nacheinander zu akkumulieren; Verwenden eines Zeigers, um auf die Elemente nacheinander zuzugreifen und zu akkumulieren; Betrachten Sie für große Datenvolumina parallele Berechnungen.

Wie erhalten Sie Echtzeit-Anwendungs- und Zuschauerdaten auf der Arbeit von 58.com? Wie erhalten Sie Echtzeit-Anwendungs- und Zuschauerdaten auf der Arbeit von 58.com? Apr 05, 2025 am 08:06 AM

Wie erhalte ich dynamische Daten von 58.com Arbeitsseite beim Kriechen? Wenn Sie eine Arbeitsseite von 58.com mit Crawler -Tools kriechen, können Sie auf diese begegnen ...

Kopieren Sie den Liebescode und fügen Sie den Liebescode kostenlos kopieren und einfügen Kopieren Sie den Liebescode und fügen Sie den Liebescode kostenlos kopieren und einfügen Apr 04, 2025 am 06:48 AM

Das Kopieren und Einfügen des Codes ist nicht unmöglich, sollte aber mit Vorsicht behandelt werden. Abhängigkeiten wie Umgebung, Bibliotheken, Versionen usw. im Code stimmen möglicherweise nicht mit dem aktuellen Projekt überein, was zu Fehlern oder unvorhersehbaren Ergebnissen führt. Stellen Sie sicher, dass der Kontext konsistent ist, einschließlich Dateipfade, abhängiger Bibliotheken und Python -Versionen. Wenn Sie den Code für eine bestimmte Bibliothek kopieren und einfügen, müssen Sie möglicherweise die Bibliothek und ihre Abhängigkeiten installieren. Zu den häufigen Fehlern gehören Pfadfehler, Versionskonflikte und inkonsistente Codestile. Die Leistungsoptimierung muss gemäß dem ursprünglichen Zweck und den Einschränkungen des Codes neu gestaltet oder neu gestaltet werden. Es ist entscheidend, den Code zu verstehen und den kopierten kopierten Code zu debuggen und nicht blind zu kopieren und einzufügen.

See all articles