


Detaillierte Erläuterung der Methode der Bucket-Sortierung des Java-Zahlenvervollständigungsalgorithmus
Dieser Artikel stellt hauptsächlich die Java-Datenstruktur und die Implementierungsmethode für die Bucket-Sortierung vor. Er analysiert das Konzept, das Prinzip, die Implementierungsmethode und die damit verbundenen Betriebsfähigkeiten der Bucket-Sortierung im Detail anhand konkreter Beispiele.
Das Beispiel in diesem Artikel beschreibt die Implementierungsmethode der Bucket-Sortierung der Java-Datenstruktur und des Algorithmus. Teilen Sie es wie folgt als Referenz mit allen:
Grundidee:
Angenommen, die Eingabe wird durch einen zufälligen Prozess generiert [0 , M ) gleichmäßig verteilte reelle Zahlen auf dem Intervall. Teilen Sie das Intervall [0, M) in n Unterintervalle (Buckets) gleicher Größe auf, weisen Sie diesen Buckets n Eingabeelemente zu, sortieren Sie die Elemente in den Buckets und verbinden Sie dann die Bucket-Eingänge 0 ≤ A[1.. n]
[Bucket - Keyword] MappingFunktion
bindex=f(key) Wobei Bindex der Bucket ist Index des Arrays B (d. h. des Bindex-Buckets), k ist der Schlüssel der zu sortierenden Spalte. Der Schlüssel zur Effizienz der Bucket-Sortierung liegt in dieser Zuordnungsfunktion, die Folgendes tun muss: Wenn das Schlüsselwort k1
Wenn die zu sortierende Spalte K= { ist. 49, 38, 35, 97, 76, 73, 27, 49}. Diese Daten liegen alle zwischen 1 und 100. Daher passen wir 10 Buckets an und bestimmen die Zuordnungsfunktion f(k)=k/10. Dann wird das erste Schlüsselwort 49 im 4. Bucket positioniert (49/10=4). Stapeln Sie alle Schlüsselwörter nacheinander in Buckets und führen Sie eine schnelle Sortierung in jedem nicht leeren Bucket durch, um das folgende Bild zu erhalten:
Solange die Reihenfolge des obigen Bildes ausgegeben wird die Daten in jedem B[i], um eine geordnete Sequenz zu erhalten.
Der Kerncode des Algorithmus lautet wie folgt:
/// <summary> /// 桶排序 /// ///如果有重复的数字,则需要 List<int>数组,这里举的例子没有重复的数字 /// </summary> /// <param name="unsorted">待排数组</param> /// <param name="maxNumber">待排数组中的最大数,如果可以提供的话</param> /// <returns></returns> static int[] bucket_sort(int[] unsorted, int maxNumber = 97) { int[] sorted = new int[maxNumber + 1]; for (int i = 0; i < unsorted.Length; i++) { sorted[unsorted[i]] = unsorted[i]; } return sorted; } static void Main(string[] args) { int[] x = {49、 38 、 35、 97 、 76、 73 、 27、 49 }; var sorted = bucket_sort(x, 97); for (int i = 0; i < sorted.Length; i++) { if (sorted[i] > 0) Console.WriteLine(sorted[i]); } Console.ReadLine(); }
Eimer-Sortierkostenanalyse
Bucket-Sortierung nutzt die Zuordnungsbeziehung von Funktionen, um fast den gesamten Vergleichsaufwand zu reduzieren. Tatsächlich entspricht die Berechnung des f(k)-Werts der Bucket-Sortierung der Aufteilung bei der Schnellsortierung, bei der eine große Datenmenge in grundsätzlich geordnete Datenblöcke (Buckets) unterteilt wird. Dann müssen Sie nur eine erweiterte Vergleichssortierung für eine kleine Datenmenge im Bucket durchführen.
Die zeitliche Komplexität der Bucket-Sortierung von N Schlüsselwörtern ist in zwei Teile unterteilt:
(1) SchleifeBerechnen Sie dieses Mal den Bucket jeder Schlüsselwort-Zuordnungsfunktion Komplexität ist O(N).
(2) Verwenden Sie den erweiterten Vergleichssortierungsalgorithmus, um alle Daten in jedem Bucket zu sortieren. Seine zeitliche Komplexität beträgt ∑ O(Ni*logNi). Wobei Ni das Datenvolumen des i-ten Buckets ist.
Offensichtlich ist Teil (2) der entscheidende Faktor für die Leistung der Eimersortierung. Die Minimierung der Datenanzahl im Bucket ist die einzige Möglichkeit, die Effizienz zu verbessern (da die beste durchschnittliche Zeitkomplexität basierend auf der Vergleichssortierung nur O(N*logN) erreichen kann). Daher müssen wir unser Bestes geben, um die folgenden zwei Punkte zu erreichen:
(1) Die Zuordnungsfunktion f(k) kann N Daten gleichmäßig auf M Buckets verteilen, sodass jeder Bucket [ N /M] Datenmenge.
(2) Erhöhen Sie die Anzahl der Eimer so weit wie möglich. Im Extremfall kann aus jedem Bucket nur ein Datenwert abgerufen werden, wodurch der Sortiervorgang „Vergleich“ der Daten im Bucket vollständig vermieden wird. Dies ist natürlich nicht einfach, wenn die Datenmenge groß ist, führt die Funktion f(k) zu einer großen Anzahl von Bucket-Sets, was zu einer erheblichen Platzverschwendung führt. Dies ist ein Kompromiss zwischen Zeitkosten und Platzkosten.
Für N zu sortierende Daten und M Buckets beträgt die durchschnittliche Bucket-Sortierzeitkomplexität von [N/M] Daten pro Bucket:
O (N)+ O(M*(N/M)*log(N/M))=O(N+N*(logN-logM))=O(N+N*logN-N*logM)
Wenn N=M, also im Extremfall, gibt es in jedem Bucket nur einen Datenwert. Die beste Effizienz der Bucket-Sortierung kann O(N) erreichen.
Zusammenfassung: Die durchschnittliche zeitliche Komplexität der Bucket-Sortierung ist linear O(N+C), wobei C=N*(logN-logM). Im Verhältnis zum gleichen N ist die Effizienz umso höher, je größer die Anzahl der Buckets M ist, und die beste Zeitkomplexität erreicht O(N). Natürlich beträgt die Platzkomplexität der Bucket-Sortierung O(N+M). Wenn die Eingabedaten sehr groß sind und die Anzahl der Buckets auch sehr groß ist, sind die Platzkosten zweifellos teuer. Darüber hinaus ist die Eimersortierung stabil.
Die folgenden drei Punkte:
1. Die Eimersortierung ist stabil
2. Die Eimersortierung ist die schnellste unter den gängigen Sortierungen, besser als die Schnellsortierung. Noch schneller. ..in den meisten Fällen
3. Die Bucket-Sortierung ist sehr schnell, verbraucht aber auch viel Platz. Es ist im Grunde der platzraubendste Sortieralgorithmus.
Ergänzung: Im Suchalgorithmus ist die beste Zeitkomplexität des vergleichsbasierten Suchalgorithmus ebenfalls O(logN). Zum Beispiel binäre Suche, ausgeglichener Binärbaum, Rot-Schwarz-Baum usw. Die Hash-Tabelle weist jedoch eine Sucheffizienz auf linearem Niveau von O(C) auf (die Sucheffizienz erreicht O(1) ohne Konflikte). Also: Ist die Idee der Hash-Tabelle der Bucket-Sortierung ähnlich?
Tatsächlich stellt die Bucket-Sortierung besondere Anforderungen an die Datenbedingungen. Wenn das Array groß ist, werden offensichtlich Hunderte Millionen Buckets zugewiesen unmöglich. Daher hat die Bucket-Sortierung ihre Grenzen und eignet sich für Situationen, in denen die Menge der Elementwerte nicht groß ist.
【Verwandte Empfehlungen】
1. Besondere Empfehlung: Version „php Programmer Toolbox“ V0.1 herunterladen
2. Kostenloses Java-Video-Tutorial
2.Umfassende Analyse von Java-Annotationen
Das obige ist der detaillierte Inhalt vonDetaillierte Erläuterung der Methode der Bucket-Sortierung des Java-Zahlenvervollständigungsalgorithmus. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

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



In diesem Artikel haben wir die am häufigsten gestellten Fragen zu Java Spring-Interviews mit ihren detaillierten Antworten zusammengestellt. Damit Sie das Interview knacken können.

Java 8 führt die Stream -API ein und bietet eine leistungsstarke und ausdrucksstarke Möglichkeit, Datensammlungen zu verarbeiten. Eine häufige Frage bei der Verwendung von Stream lautet jedoch: Wie kann man von einem Foreach -Betrieb brechen oder zurückkehren? Herkömmliche Schleifen ermöglichen eine frühzeitige Unterbrechung oder Rückkehr, aber die Stream's foreach -Methode unterstützt diese Methode nicht direkt. In diesem Artikel werden die Gründe erläutert und alternative Methoden zur Implementierung vorzeitiger Beendigung in Strahlverarbeitungssystemen erforscht. Weitere Lektüre: Java Stream API -Verbesserungen Stream foreach verstehen Die Foreach -Methode ist ein Terminalbetrieb, der einen Vorgang für jedes Element im Stream ausführt. Seine Designabsicht ist

Anleitung zum TimeStamp to Date in Java. Hier diskutieren wir auch die Einführung und wie man Zeitstempel in Java in ein Datum konvertiert, zusammen mit Beispielen.

Kapseln sind dreidimensionale geometrische Figuren, die aus einem Zylinder und einer Hemisphäre an beiden Enden bestehen. Das Volumen der Kapsel kann berechnet werden, indem das Volumen des Zylinders und das Volumen der Hemisphäre an beiden Enden hinzugefügt werden. In diesem Tutorial wird erörtert, wie das Volumen einer bestimmten Kapsel in Java mit verschiedenen Methoden berechnet wird. Kapselvolumenformel Die Formel für das Kapselvolumen lautet wie folgt: Kapselvolumen = zylindrisches Volumenvolumen Zwei Hemisphäre Volumen In, R: Der Radius der Hemisphäre. H: Die Höhe des Zylinders (ohne die Hemisphäre). Beispiel 1 eingeben Radius = 5 Einheiten Höhe = 10 Einheiten Ausgabe Volumen = 1570,8 Kubikeinheiten erklären Berechnen Sie das Volumen mithilfe der Formel: Volumen = π × R2 × H (4

Java ist eine beliebte Programmiersprache, die sowohl von Anfängern als auch von erfahrenen Entwicklern erlernt werden kann. Dieses Tutorial beginnt mit grundlegenden Konzepten und geht dann weiter zu fortgeschrittenen Themen. Nach der Installation des Java Development Kit können Sie das Programmieren üben, indem Sie ein einfaches „Hello, World!“-Programm erstellen. Nachdem Sie den Code verstanden haben, verwenden Sie die Eingabeaufforderung, um das Programm zu kompilieren und auszuführen. Auf der Konsole wird „Hello, World!“ ausgegeben. Mit dem Erlernen von Java beginnt Ihre Programmierreise, und wenn Sie Ihre Kenntnisse vertiefen, können Sie komplexere Anwendungen erstellen.

Spring Boot vereinfacht die Schaffung robuster, skalierbarer und produktionsbereiteter Java-Anwendungen, wodurch die Java-Entwicklung revolutioniert wird. Der Ansatz "Übereinkommen über Konfiguration", der dem Feder -Ökosystem inhärent ist, minimiert das manuelle Setup, Allo

PHP und Python haben jeweils ihre eigenen Vorteile, und die Wahl sollte auf Projektanforderungen beruhen. 1.PHP eignet sich für die Webentwicklung mit einfacher Syntax und hoher Ausführungseffizienz. 2. Python eignet sich für Datenwissenschaft und maschinelles Lernen mit präziser Syntax und reichhaltigen Bibliotheken.

Java leicht gemacht: Ein Leitfaden für Anfänger zur leistungsstarken Programmierung Java ist eine leistungsstarke Programmiersprache, die in allen Bereichen von mobilen Anwendungen bis hin zu Systemen auf Unternehmensebene verwendet wird. Für Anfänger ist die Syntax von Java einfach und leicht zu verstehen, was es zu einer idealen Wahl zum Erlernen des Programmierens macht. Grundlegende Syntax Java verwendet ein klassenbasiertes objektorientiertes Programmierparadigma. Klassen sind Vorlagen, die zusammengehörige Daten und Verhaltensweisen organisieren. Hier ist ein einfaches Java-Klassenbeispiel: publicclassPerson{privateStringname;privateintage;
