FREE tools

Bubble Sort in Java: Ein einfacher Leitfaden mit Codebeispielen

Lukas Fuchs vor 10 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

Die umfassende Outlook Symbol Übersicht: Verstehen und Nutzen

AUTOR • May 16, 2026
DevOps & Deployment

So installierst du den ComfyUI Manager: Eine Schritt-für-Schritt-Anleitung

AUTOR • May 16, 2026
Full-Stack

Node-RED Anleitung: Der ultimative Einstieg in die visuelle Programmierung

AUTOR • May 16, 2026
Webdesign & UX

Die besten Methoden zum Virus entfernen: So bleibst du sicher im Netz

AUTOR • May 16, 2026
Performance & SEO

Effektive Nutzung von MS Teams Breakout Rooms für interaktive Meetings

AUTOR • May 16, 2026
Backend-Entwicklung

Pseudocode Beispiel: Effektives Programmieren leicht gemacht

AUTOR • May 16, 2026
Webdesign & UX

Numbered List Markdown

AUTOR • May 16, 2026
DevOps & Deployment

Home Assistant Standard Port: Ein umfassender Leitfaden zur Konfiguration und Sicherheit

AUTOR • May 16, 2026
Webdesign & UX

Die Schritte zum effektiven Tab Löschen in Browsern

AUTOR • May 16, 2026
DevOps & Deployment

So behebst du die Fehlermeldung 'Reolink Verbindung fehlgeschlagen'

AUTOR • May 16, 2026
Backend-Entwicklung

Metabox Lifetime Deal

AUTOR • May 12, 2026
Webdesign & UX

Azure DevOps-Symbol: Bedeutung, Verwendung und Download

AUTOR • May 11, 2026
Webdesign & UX

Das Lupe-Symbol: Unverzichtbares Werkzeug für die Online-Suche

AUTOR • May 11, 2026
Webdesign & UX

Die ultimative Anleitung zur Home Assistant Dokumentation in Deutsch

AUTOR • May 04, 2026
Frontend-Entwicklung

Node-RED Dashboard Aufrufen: Schritt-für-Schritt-Anleitung für Einsteiger

AUTOR • May 04, 2026
Webdesign & UX

Wie du dein Google Konto Altersbeschränkungen bestätigen kannst

AUTOR • May 04, 2026
Webdesign & UX

How to Use Friendly Captcha

AUTOR • May 04, 2026
Webdesign & UX

Der Fully Kiosk Browser für Home Assistant: Eine umfassende Anleitung auf Deutsch

AUTOR • May 04, 2026
Performance & SEO

UTF-8 und Umlaute: Alles, was Sie wissen müssen

AUTOR • May 04, 2026
Webdesign & UX

So fügen Sie einen Haken in Outlook ein – Schritt-für-Schritt-Anleitung

AUTOR • May 04, 2026

Beliebte Beiträge

Performance & SEO

How to Encode Email Addresses

AUTOR • Dec 31, 2023
Webdesign & UX

Outlook Übermittlungsfehler Löschen: Schritt-für-Schritt Anleitung zur Fehlerbehebung

AUTOR • Mar 11, 2026
DevOps & Deployment

Windows 11 Benutzer ändern: Eine Schritt-für-Schritt-Anleitung

AUTOR • Dec 19, 2025
Webdesign & UX

ANSI Converter: Simplify Text Formatting Effortlessly

AUTOR • Sep 04, 2024
Performance & SEO

Excel Tabelle Größe Anpassen: So Optimieren Sie Ihre Arbeitsblätter

AUTOR • Jun 27, 2025
Webdesign & UX

Serienbrief in Excel erstellen: Schritt-für-Schritt-Anleitung

AUTOR • Jul 01, 2025
Webdesign & UX

Die Lenovo Seriennummer finden: Eine Schritt-für-Schritt-Anleitung

AUTOR • Jun 26, 2025
DevOps & Deployment

Drucker einrichten und nutzen unter Windows 11: Eine Schritt-für-Schritt-Anleitung

AUTOR • Jun 23, 2025
Webdesign & UX

Die besten Tipps, um alt Outlook zu bekommen und zu nutzen

AUTOR • Jun 12, 2025
Webdesign & UX

Der Speicherort von Screenshots mit Windows + Shift + S: Alles, was du wissen musst

AUTOR • Jun 21, 2025
Frontend-Entwicklung

The Ultimate WordPress Offline Editors

AUTOR • Mar 04, 2024
Webdesign & UX

Dauerhaft die Menüleiste in Word einblenden: So geht's!

AUTOR • Jun 17, 2025
Webdesign & UX

Excel CSV speichern mit Komma: Eine Schritt-für-Schritt-Anleitung

AUTOR • Jun 27, 2025
Backend-Entwicklung

Wie Du Spotify mit 2FA absicherst: Eine Schritt-für-Schritt-Anleitung

AUTOR • Jul 11, 2025
Webdesign & UX

Outlook Klassisch Ansicht Einstellen: So gelingt es mühelos

AUTOR • Dec 15, 2025
DevOps & Deployment

Microsoft SARA Tool Download: Alles, was Sie wissen müssen

AUTOR • Jun 18, 2025
Webdesign & UX

Adblocker unter Chrome für Android aktivieren: Schritt für Schritt Anleitung

AUTOR • Jun 08, 2025
Frontend-Entwicklung

How to Write a Quote in Markdown

AUTOR • Feb 22, 2024
Webdesign & UX

Effiziente Zusammenarbeit: Outlook Kalender Freigabe Anfordern leicht gemacht

AUTOR • Jun 08, 2025
Webdesign & UX

Excel-Datei Schreibschutz aktivieren: So geht's!

AUTOR • Jun 17, 2025