FREE tools

Bubble Sort in Java: Ein einfacher Leitfaden mit Codebeispielen

Lukas Fuchs vor 11 Monaten Backend-Entwicklung 3 Min. Lesezeit

Entdecke, was Bubble Sort ist und wie du diesen Algorithmus in Java implementieren kannst. In diesem Artikel erfährst du alles, was du über den Bubble Sort Algorithmus wissen musst, inklusive klarer Beispiele und nützlicher Tipps.

Was ist Bubble Sort?

Bubble Sort ist ein einfacher Sortieralgorithmus, der häufig in der Informatik verwendet wird, um Daten in aufsteigender (oder absteigender) Reihenfolge zu sortieren. Der Algorithmus funktioniert, indem er wiederholt benachbarte Elemente vergleicht und sie vertauscht, wenn sie in der falschen Reihenfolge sind. Obwohl dieser Algorithmus nicht so effizient ist wie andere Sortiermethoden, ist er ideal für Lernzwecke und eignet sich gut für kleine Datenmengen.

Wie funktioniert Bubble Sort?

Der Bubble Sort Algorithmus extrahiert den größten (oder kleinsten) Wert aus dem nicht sortierten Teil der Liste und platziert ihn am Anfang oder Ende des sortierten Teils. Diese Bewegung wird so lange wiederholt, bis die gesamte Liste sortiert ist.

Algorithmus Schritt-für-Schritt

  1. Beginne bei der ersten Position der Liste.
  2. Vergleiche das aktuelle Element mit dem nächsten Element.
  3. Wenn das aktuelle Element größer ist als das nächste, vertausche die beiden Elemente.
  4. Bewege dich zum nächsten Element und wiederhole den Vorgang.
  5. Wenn du das Ende der Liste erreicht hast, gehe zurück zum Anfang und wiederhole den gesamten Vorgang für die restlichen Elemente.
  6. Wiederhole die Schritte, bis keine Vertauschungen mehr nötig sind.

Bubble Sort in Java: Implementierung

Hier ist ein einfaches Beispiel für die Implementierung von Bubble Sort in Java:

public class BubbleSort {
    public static void bubbleSort(int[] arr) {
        int n = arr.length;
        boolean swapped;
        
        do {
            swapped = false;
            for (int i = 1; i < n; i++) {
                if (arr[i - 1] > arr[i]) {
                    // Vertauschen
                    int temp = arr[i - 1];
                    arr[i - 1] = arr[i];
                    arr[i] = temp;
                    swapped = true;
                }
            }
            n--;
        } while (swapped);
    }

    public static void main(String[] args) {
        int[] myArray = {64, 34, 25, 12, 22, 11, 90};
        bubbleSort(myArray);
        System.out.println("Sorted array:");
        for (int num : myArray) {
            System.out.print(num + " ");
        }
    }
}

Erklärung des Codes

Im obigen Code haben wir eine Klasse BubbleSort definiert, die die Sortierlogik kapselt. Die Methode bubbleSort erhält ein Array von Ganzzahlen:

  • Die Länge des Arrays wird gespeichert, um die Schleifen zu steuern.
  • Eine do-while-Schleife wird verwendet, um sicherzustellen, dass der Vorgang so oft wie nötig wiederholt wird.
  • Innerhalb der Schleife erfolgt der Vergleich und das Vertauschen von Elementen.

Vor- und Nachteile von Bubble Sort

Vorteile

  • Einfach zu verstehen und zu implementieren.
  • Kann bei kleineren Arrays relativ schnell sein.
  • Stabiler Algorithmus: Die Reihenfolge von gleichen Elementen bleibt erhalten.

Nachteile

  • In der Zeitkomplexität von O(n²) ineffizient für große Datenmengen.
  • Wird in der Praxis selten eingesetzt aufgrund seiner langsamen Leistung im Vergleich zu anderen Sortieralgorithmen.

Fazit

Bubble Sort ist ein großartiger Algorithmus für den Einstieg in die Sortierung, da er leicht zu verstehen und zu implementieren ist. Er hat jedoch erhebliche Einschränkungen in Bezug auf Effizienz. Wenn du mit größeren Datensätzen arbeitest, solltest du effizientere Algorithmen wie Quick Sort oder Merge Sort in Betracht ziehen. Dennoch ist Bubble Sort eine wichtige Lernerfahrung in der Programmierung und gibt einen hervorragenden Einblick in grundlegende Algorithmen.

Für mehr Informationen und Beispiele zu Java-Algorithmen, besuche unsere Website für weitere Artikel.

Weitere Beiträge

Folge uns

Neue Beiträge

Webdesign & UX

PageLayer vs Elementor: Which WordPress Theme Should You Choose?

AUTOR • Jun 23, 2026
DevOps & Deployment

Gerät Netzwerk anzeigen CMD: So findest du Netzwerkgeräte am PC in Sekunden

AUTOR • Jun 23, 2026
Webdesign & UX

Bedingte Formatierung Formel in Excel: So steuerst du Farben, Regeln und Ausnahmen sauber

AUTOR • Jun 23, 2026
Webdesign & UX

Popup Blocker deaktivieren Firefox: So schaltest du Pop-ups gezielt frei

AUTOR • Jun 23, 2026
Webdesign & UX

So erstellen Sie einfach und schnell eine PNG-Datei

AUTOR • Jun 23, 2026
Webdesign & UX

Excel Kalenderwoche einfügen: So berechnest und nutzt du KW in Excel sauber

AUTOR • Jun 23, 2026
Backend-Entwicklung

For Each VBA richtig nutzen: Schleifen in Excel schneller und sauberer schreiben

AUTOR • Jun 23, 2026
Webdesign & UX

Telefon Zeichen in Word einfügen: So klappt es schnell und sauber

AUTOR • Jun 23, 2026
DevOps & Deployment

Externe Festplatte initialisieren: So richtest du sie richtig ein und vermeidest Fehler

AUTOR • Jun 23, 2026
Webdesign & UX

Die besten Instagram-Erweiterungen für Chrome: So optimierst du deine Nutzung

AUTOR • Jun 23, 2026
Performance & SEO

Excel vergleichen mit Substring: Teilstrings sauber prüfen, extrahieren und matchen

AUTOR • Jun 23, 2026
Backend-Entwicklung

Shared Lock: Was es ist, wann du es brauchst und wie du es richtig einsetzt

AUTOR • Jun 23, 2026
Backend-Entwicklung

PHP DateTime now: Aktuelles Datum und Uhrzeit sauber abrufen

AUTOR • Jun 22, 2026
Webdesign & UX

Das WWW-Symbol: Warum es ein unverzichtbares Element des modernen Internets ist

AUTOR • Jun 22, 2026
APIs & Microservices

How to generate an API key for your WordPress website: So bekommst du den Key schnell und sicher

AUTOR • Jun 22, 2026
DevOps & Deployment

Windows 7 ohne Aktivierungsschlüssel aktivieren: Was wirklich geht und was nicht

AUTOR • Jun 22, 2026
Webdesign & UX

taskkill Windows: Prozesse in Windows schnell und sauber beenden

AUTOR • Jun 22, 2026
Webdesign & UX

PDF Vorlage erstellen: So baust du schnell professionelle Vorlagen, die wirklich genutzt werden

AUTOR • Jun 22, 2026
DevOps & Deployment

Wiederherstellung Partition neu erstellen: So rettest du Daten und strukturierst deine Festplatte richtig

AUTOR • Jun 22, 2026
Backend-Entwicklung

Logisches Oder Zeichen: Bedeutung, Beispiele und Anwendung in Mathe, Programmierung und Logik

AUTOR • Jun 22, 2026

Beliebte Beiträge

Backend-Entwicklung

Pandas Shift: Effektives Arbeiten mit Zeitreihen in Python

AUTOR • Jul 08, 2025
Backend-Entwicklung

PHP var_dump to String: So wandeln Sie var_dump-Ausgaben in Strings um

AUTOR • Sep 27, 2024
Frontend-Entwicklung

Die vielseitige Verwendung von Input Checkboxen: Antworten auf häufige Fragen

AUTOR • Sep 27, 2024
DevOps & Deployment

Hotfix: Was es ist und warum es für Softwareentwickler unverzichtbar ist

AUTOR • Jul 16, 2025
Webdesign & UX

bginfo: Das leistungsstarke Tool zur Desktop-Anpassung für Windows

AUTOR • Jul 16, 2025
DevOps & Deployment

Ad Replikation Prüfen: Ein Leitfaden für Systemadministratoren

AUTOR • Jul 16, 2025
Frontend-Entwicklung

Die Zukunft des Internets: Was ist ein Web Client und wie funktioniert er?

AUTOR • Jul 04, 2025
DevOps & Deployment

AWS Domain: Der ultimative Leitfaden für Ihre Online-Präsenz

AUTOR • Jul 03, 2025
DevOps & Deployment

Die besten Huawei USB Treiber für eine reibungslose Verbindung

AUTOR • Jun 26, 2025
Frontend-Entwicklung

Die besten Tipps zum Suchen von Outlook E-Mails effizient und schnell

AUTOR • Jun 26, 2025
Webdesign & UX

Die besten Methoden, um eine TXT-Datei auf Android zu öffnen

AUTOR • Jun 25, 2025
Webdesign & UX

So fügen Sie das Herz-Zeichen auf Ihrer Tastatur ein: Eine einfache Anleitung

AUTOR • Jun 19, 2025
Backend-Entwicklung

Die Kunst der Organisation: So nutzen Sie Labels in Gmail effektiv

AUTOR • Jun 19, 2025
Webdesign & UX

Die "Wenn"-Formel in Excel: Ein unverzichtbares Werkzeug für deine Datenanalyse

AUTOR • Jun 18, 2025
Webdesign & UX

Die besten Methoden zum Öffnen von ZIP-Dateien: Einfach erklärt!

AUTOR • Jun 17, 2025
Backend-Entwicklung

Was bedeutet C? Eine umfassende Definition und Einführung in die Programmiersprache

AUTOR • Jun 16, 2025
Webdesign & UX

Effizientes Arbeiten mit Gmail: So zeigen Sie Ihr Archiv an

AUTOR • Jun 14, 2025
Webdesign & UX

Die besten kostenlosen Alternativen zu Doodle für Terminplanungen

AUTOR • Jun 12, 2025
Webdesign & UX

The Best WordPress Chat Plugins

AUTOR • Dec 19, 2023
Backend-Entwicklung

Die richtige Verwendung von Platzhaltern in Python: Tipps und Tricks

AUTOR • Jul 16, 2025