suchen
HeimJavajavaLernprogrammDetaillierte 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] ArrayB[0..n-1] ist ein Array von Zeigern, die auf den Bucket (verknüpfte Liste) zeigen. Verteilen Sie n Datensätze an jeden Bucket. Wenn mehr als ein Datensatz demselben Bucket zugeordnet ist, ist eine Sortierung innerhalb des Buckets erforderlich. Listen Sie abschließend die Datensätze in jedem Bucket der Reihe nach auf und merken Sie sich diese in einer geordneten Reihenfolge.

[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 k1Natürlich Die Bestimmung der Zuordnungsfunktion steht in engem Zusammenhang mit den Eigenschaften der Daten selbst Geben wir unten ein Beispiel:

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!

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
Erklären Sie, wie die JVM als Vermittler zwischen dem Java -Code und dem zugrunde liegenden Betriebssystem fungiert.Erklären Sie, wie die JVM als Vermittler zwischen dem Java -Code und dem zugrunde liegenden Betriebssystem fungiert.Apr 29, 2025 am 12:23 AM

JVM arbeitet mit dem Konvertieren von Java -Code in Maschinencode und Verwaltung von Ressourcen. 1) Ladeklasse: Laden Sie die .class -Datei in den Speicher. 2) Laufzeitdatenbereich: Speicherbereich verwalten. 3) Ausführungs Engine: Ausführungsbytecode interpretieren oder kompilieren. 4) Lokale Methodenschnittstelle: Interagieren Sie mit dem Betriebssystem über JNI.

Erklären Sie die Rolle der Java Virtual Machine (JVM) in der Unabhängigkeit der Plattform von Java.Erklären Sie die Rolle der Java Virtual Machine (JVM) in der Unabhängigkeit der Plattform von Java.Apr 29, 2025 am 12:21 AM

Mit JVM kann Java auf Plattformen rennen. 1) JVM lädt, validiert und führt Bytecode aus. 2) Die Arbeit von JVM umfasst Klassenbelastung, Bytecode -Überprüfung, Interpretationsausführung und Speicherverwaltung. 3) JVM unterstützt erweiterte Funktionen wie dynamisches Klassenbelastung und Reflexion.

Welche Schritte würden Sie unternehmen, um sicherzustellen, dass eine Java -Anwendung in verschiedenen Betriebssystemen korrekt ausgeführt wird?Welche Schritte würden Sie unternehmen, um sicherzustellen, dass eine Java -Anwendung in verschiedenen Betriebssystemen korrekt ausgeführt wird?Apr 29, 2025 am 12:11 AM

Java -Anwendungen können in verschiedenen Betriebssystemen in den folgenden Schritten ausgeführt werden: 1) Verwenden Sie die Datei- oder Pfadeklasse, um Dateipfade zu verarbeiten; 2) Umgebungsvariablen durch system.getenv () einstellen und erhalten; 3) Verwenden Sie Maven oder Gradle, um Abhängigkeiten zu verwalten und zu testen. Die plattformübergreifenden Funktionen von Java beruhen auf der Abstraktionsschicht der JVM, erfordern jedoch eine manuelle Handhabung bestimmter Betriebssystem-spezifischer Funktionen.

Gibt es Bereiche, in denen Java plattformspezifische Konfiguration oder Tuning benötigt?Gibt es Bereiche, in denen Java plattformspezifische Konfiguration oder Tuning benötigt?Apr 29, 2025 am 12:11 AM

Java benötigt eine spezifische Konfiguration und das Tuning auf verschiedenen Plattformen. 1) Passen Sie die JVM -Parameter an, z. B. -xms und -xmx, um die Haufengröße festzulegen. 2) Wählen Sie die entsprechende Strategie für die Müllsammlung, wie z. B. ParallelgC oder G1GC. 3) Konfigurieren Sie die native Bibliothek, um sich an verschiedene Plattformen anzupassen. Diese Maßnahmen können es Java -Anwendungen ermöglichen, in verschiedenen Umgebungen am besten zu funktionieren.

Was sind einige Tools oder Bibliotheken, mit denen Sie plattformspezifische Herausforderungen in der Java-Entwicklung bewältigen können?Was sind einige Tools oder Bibliotheken, mit denen Sie plattformspezifische Herausforderungen in der Java-Entwicklung bewältigen können?Apr 29, 2025 am 12:01 AM

Osgi, Apachecommonslang, JNA und JVMOPTIONSAREEFECTIVEFORHANDLATTLATFORM-Spezifikaldesinjava.1) OsgimanagesDependenciesandisolatesComponents.2) apachecommonslangprovidilityfunctions.3) jnaAllowscallingnativeStivingnativeCallingnativeCode

Wie verwaltet der JVM die Müllsammlung auf verschiedenen Plattformen?Wie verwaltet der JVM die Müllsammlung auf verschiedenen Plattformen?Apr 28, 2025 am 12:23 AM

JvmmanagesGecollectionAcrossplattformseffektivyusingagenerationalApproachandaDaptoosandhardwaredFerces

Warum kann Java -Code auf verschiedenen Betriebssystemen ohne Änderung ausgeführt werden?Warum kann Java -Code auf verschiedenen Betriebssystemen ohne Änderung ausgeführt werden?Apr 28, 2025 am 12:14 AM

Java -Code kann auf verschiedenen Betriebssystemen ohne Änderung ausgeführt werden, da Javas "einmal schreiben, überall rennen" von Java Virtual Machine (JVM) implementiert wird. Als Vermittler zwischen dem kompilierten Java -Bytecode und dem Betriebssystem übersetzt das JVM die Bytecode in bestimmte Maschinenanweisungen, um sicherzustellen, dass das Programm mit installiertem JVM unabhängig auf jeder Plattform ausführen kann.

Beschreiben Sie den Prozess der Erstellung und Ausführung eines Java -Programms, wodurch die Unabhängigkeit der Plattform hervorgehoben wird.Beschreiben Sie den Prozess der Erstellung und Ausführung eines Java -Programms, wodurch die Unabhängigkeit der Plattform hervorgehoben wird.Apr 28, 2025 am 12:08 AM

Die Zusammenstellung und Ausführung von Java -Programmen erreicht die Unabhängigkeit der Plattform über Bytecode und JVM. 1) Schreiben Sie Java -Quellcode und kompilieren Sie ihn in Bytecode. 2) Verwenden Sie JVM, um Bytecode auf einer beliebigen Plattform auszuführen, um sicherzustellen, dass der Code über Plattformen hinweg ausgeführt wird.

See all articles

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

Video Face Swap

Video Face Swap

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

Heiße Werkzeuge

MinGW – Minimalistisches GNU für Windows

MinGW – Minimalistisches GNU für Windows

Dieses Projekt wird derzeit auf osdn.net/projects/mingw migriert. Sie können uns dort weiterhin folgen. MinGW: Eine native Windows-Portierung der GNU Compiler Collection (GCC), frei verteilbare Importbibliotheken und Header-Dateien zum Erstellen nativer Windows-Anwendungen, einschließlich Erweiterungen der MSVC-Laufzeit zur Unterstützung der C99-Funktionalität. Die gesamte MinGW-Software kann auf 64-Bit-Windows-Plattformen ausgeführt werden.

SublimeText3 Englische Version

SublimeText3 Englische Version

Empfohlen: Win-Version, unterstützt Code-Eingabeaufforderungen!

SublimeText3 Linux neue Version

SublimeText3 Linux neue Version

SublimeText3 Linux neueste Version

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Herunterladen der Mac-Version des Atom-Editors

Herunterladen der Mac-Version des Atom-Editors

Der beliebteste Open-Source-Editor