MergeSort (für Anfänger )

Hallo an Alle,
ich muss das MergeSort Verfahren implementieren, allerdings will das nicht wirklich klappen. Vielleicht kann mir jemand weiter helfen? Die Methode mergeSort wurde vom Professor schon vorgegeben.
Das hier habe ich bisher:
Java:
import java.util.Arrays;

public class MergeSort {

    public static void main(String[] args) {
        int[] array = {149, 45, 76, 0, 93, 15, 39, -5};
        mergeSort(array, 0, array.length-1);
        System.out.println("Sortiertes Array: " + Arrays.toString(array));

    }
// Sortieren des Teil-Arrays a[l]..a[r]

    private static void mergeSort(int[] a, int l, int r) {
        if (r <= l) { //rechts kleiner links
            return; // nur 1 Element => fertig.
        }
        int m = (l + r) / 2;
        mergeSort(a, l, m); // linke Hälfte sortieren
        mergeSort(a, m + 1, r); // rechte Hälfte sortieren
        merge(a, l, m, r); // beide Hälften zusammenmischen

    }
// Mischen der Teil-Arrays l..p und p+1..r

    private static void merge(int[] a, int l, int p, int r) {

        int[] sortedArray = new int[a.length];
        for (int k = l; k < r; k++) { 

            for (int i = 0; i < p; i++) {
                for (int j = p + 1; j < r; j++) {

                    if (a[j] <= a[i]) {
                        sortedArray[k] = a[j];
                        
                    } else {
                        sortedArray[k] = a[i];
                        
                    }
                }
            }
        }
    }
}
 

DrZoidberg

Top Contributor
Am Ende der merge Methode musst Du den Inhalt von sortedArray nach a kopieren.
Ausserdem sollte es k <= r heissen und nicht k < r.
Und Du kannst auch nicht zwei verschachtelte Schleifen verwenden. Nimm eine while Schleife und erhöhe dann jeweils i bzw j. z.b. so
Java:
if (a[j] <= a[i]) {
    sortedArray[k] = a[j++];
} else {
    sortedArray[k] = a[i++];
}
 
Ich danke dir. Nun habe ich versucht das mal umzusetzen. Allerdings bekomme ich nun eine ArrayIndexOutOfBoundsException
Java:
 private static void merge(int[] a, int l, int p, int r) {

        int[] sortedArray = new int[a.length];
        for (int k = l; k <= r; k++) { // neues array befüllen

            int i = 0;
            int j = p + 1;
            while (i <= p) {

                if (a[j] <= a[i]) {
                    sortedArray[k] = a[j];
                    j++;
                } else {
                    sortedArray[k] = a[i];
                    i++;
                }
            }
        
        a[k] = sortedArray[k];
    }
}
}
 
Zuletzt bearbeitet:

DrZoidberg

Top Contributor
So könnte es gehen

Java:
private static void merge(int[] a, int l, int p, int r) {
    int[] sortedArray = new int[r-l+1];
    int i = l;
    int j = p + 1;
    for(int k = 0; k < sortedArray.length; k++) {
        if(i > p || (j <= r && a[i] > a[j])) {
            sortedArray[k] = a[j];
            j++;
        } else {
            sortedArray[k] = a[i];
            i++;
        }
    }
    for(int k = 0; k < sortedArray.length; k++) {
        a[k+l] = sortedArray[k];
    }
}
 
Ich habe eine Frage zu deiner if-Abfrage.
In welchem Punkt kann i > p sein, wenn doch der erste teil des arrays von i= links und p = mitte geht und innerhalb dieser grenzen schon sortiert ist?

leider bekomme ich aber noch immer eine ArrayIndexOutOfBoundException
 

JavaMeister

Gesperrter Benutzer
Was steht in der Zeile in der die Exception kommt?

Wieso debuggst du nicht die indexe dort?

Ist dir klar, wie so eine Exception kommt und warum?
 

DrZoidberg

Top Contributor
Stell dir mal vor das Array sieht so aus
int[] a = {1,2,3,7,8};
und du schreibst dann merge(a, 0, 2, 4);
Dann kopiert die Methode erstmal 1,2 und 3 nach sortedArray, danach ist i dann 3 also zu gross.
Mit anderen Worten, wenn eine der beiden Hälften komplett abgearbeitet ist (i > p oder j > r), dann kann man nur noch aus der anderen Hälfte lesen.

Hier mal ein komplettes Programm. Funktioniert bei mir einwandfrei.

Java:
import java.util.Arrays;
import java.util.Random;

public class MergeSort {
    private static void mergeSort(int[] a, int l, int r) {
        if (r <= l) {
            return;
        }
        int m = (l + r) / 2;
        mergeSort(a, l, m);
        mergeSort(a, m + 1, r);
        merge(a, l, m, r);
    
    }

    private static void merge(int[] a, int l, int p, int r) {
        int[] sortedArray = new int[r-l+1];
        int i = l;
        int j = p + 1;
        for(int k = 0; k < sortedArray.length; k++) {
            if(i > p || (j <= r && a[i] > a[j])) {
                sortedArray[k] = a[j];
                j++;
            } else {
                sortedArray[k] = a[i];
                i++;
            }
        }
        for(int k = 0; k < sortedArray.length; k++) {
            a[k+l] = sortedArray[k];
        }
    }
    
    public static void main(String[] args) throws Exception {
        Random rand = new Random();
        int[] a = new int[1000];
        for(int i = 0; i < a.length; i++) {
            a[i] = rand.nextInt(100);
        }

        mergeSort(a, 0, a.length-1);
        System.out.println(Arrays.toString(a));
    }
}
 
Ich danke dir :)
Ich habe meinen Fehler gefunden.
Für das sortedArray habe ich, anders als du, Speicher reserviert in Höhe von a.length. Du Hingegen hast ja (r-l+1) geschrieben. Daran hats gelegen.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
L Mergesort (aber anders) Java Basics - Anfänger-Themen 2
KogoroMori21 MergeSort Algorithmus Java Basics - Anfänger-Themen 2
O Rekursion Mergesort Java Basics - Anfänger-Themen 18
E Methoden 2 Arrays sortieren (MergeSort) Java Basics - Anfänger-Themen 3
H Mergesort aufwand berechen Java Basics - Anfänger-Themen 5
I MergeSort iterativ mit Stacks Java Basics - Anfänger-Themen 13
L Methoden Mergesort methode Java Basics - Anfänger-Themen 4
K MergeSort Stackoverflow Java Basics - Anfänger-Themen 5
K Mergesort Fehler in der Implementierung Java Basics - Anfänger-Themen 2
T MergeSort rekursiv programmieren Java Basics - Anfänger-Themen 8
A Rekursion (anhand von Mergesort) nachvollziehen Java Basics - Anfänger-Themen 4
M Erklärung Code Mergesort Bitte Java Basics - Anfänger-Themen 3
A Probleme mit MergeSort Generische Liste Java Basics - Anfänger-Themen 0
M Mergesort Aufgabe große Probleme Java Basics - Anfänger-Themen 9
P Mergesort Probleme Java Basics - Anfänger-Themen 4
I Mergesort mit ArrayList Java Basics - Anfänger-Themen 4
C Mergesort Java Basics - Anfänger-Themen 4
N MergeSort Java Basics - Anfänger-Themen 8
M MergeSort - Zahlen verschwinden Java Basics - Anfänger-Themen 2
P MergeSort mit Liste Java Basics - Anfänger-Themen 4
M MergeSort rekursiv Java Basics - Anfänger-Themen 2
B Methoden Natural Mergesort Java Basics - Anfänger-Themen 2
P Mergesort || 2 SetLists mischen Java Basics - Anfänger-Themen 2
P Mergesort (zyklische Liste) Java Basics - Anfänger-Themen 2
X eigener Mergesort auf generischen Typen mit Comparator Java Basics - Anfänger-Themen 6
N MergeSort mit Liste Java Basics - Anfänger-Themen 8
P Probleme bei codierung von MergeSort Java Basics - Anfänger-Themen 4
M MergeSort - Threads in Anwendung bremsen alles! Java Basics - Anfänger-Themen 4
Houly Mergesort Java Basics - Anfänger-Themen 4
M Mergesort Java Basics - Anfänger-Themen 11
C MergeSort Problem Java Basics - Anfänger-Themen 5
F MergeSort iterativ mit Hilfe von Stack Java Basics - Anfänger-Themen 5
B mergesort/rekursion Java Basics - Anfänger-Themen 9
W Methoden java map ersatz für c++map Java Basics - Anfänger-Themen 2
A csv Reader für Java? Java Basics - Anfänger-Themen 24
S Bitte Ratschläge für Console-MenuFührung... Java Basics - Anfänger-Themen 20
tomzen Java Unterstützung für exel dateien installieren. Java Basics - Anfänger-Themen 2
M Code aus IntelliJ in "Textform" für Word-Paper? Java Basics - Anfänger-Themen 10
G Icon für App Java Basics - Anfänger-Themen 1
Kerstininer Vererbung Hilfe beim lernen von Objektorientierung für eine Klausur Java Basics - Anfänger-Themen 10
Sniper1000 Java 391 für Windows Java Basics - Anfänger-Themen 37
P Wieso kann ich als Index für einen Array einen Char angeben? Java Basics - Anfänger-Themen 3
benny1993 Java Programm erstellen für ein Fußball-Turnier Java Basics - Anfänger-Themen 3
V Durchschnittliche Volatility in Prozent für 4 Stunden berechnen Java Basics - Anfänger-Themen 14
P Welches SDK für das erstellen einer ausführbaren Datei? Java Basics - Anfänger-Themen 4
C negamax-Algorithmus für Tic-Tac-Toe spielt manchmal falsch Java Basics - Anfänger-Themen 10
D Apache HTTPClient für alle Fälle Java Basics - Anfänger-Themen 41
J Layout Manager, welcher ist der Richtige für mein Program? Java Basics - Anfänger-Themen 1
J Fehlermeldung unverständlich für Jakarta Java Basics - Anfänger-Themen 17
M Minimax-Algorithmus für Vier gewinnt Java Basics - Anfänger-Themen 11
M GUI für Vier-Gewinnt. Java Basics - Anfänger-Themen 4
I JPA Query für mehrere Klassen Java Basics - Anfänger-Themen 3
D Quellcode für cmd funktioniert nicht Java Basics - Anfänger-Themen 9
R Operatoren Rechenoperation in Java verwenden für Calculator Java Basics - Anfänger-Themen 2
R Operatoren Rechenoperation verwenden für Taschenrechner. Java Basics - Anfänger-Themen 32
Ostkreuz Counter für Booleanwerte Java Basics - Anfänger-Themen 8
B Regex Ausdrücke für Monate Java Basics - Anfänger-Themen 7
I BlueJ Queue Frage für Klausur Java Basics - Anfänger-Themen 2
K loop pausieren für eine bestimmte Anzahl? Java Basics - Anfänger-Themen 1
Jxhnny.lpz Randomisier für Buttons Java Basics - Anfänger-Themen 13
W Intuitive interface für Komponenten Java Basics - Anfänger-Themen 4
M "Class<T> clazz" im Constructor - auch für int möglich? Java Basics - Anfänger-Themen 7
B Schrankensystem mit Farberkennung für Flashgame funktioniert nicht wie geplant Java Basics - Anfänger-Themen 4
I Code für Bezahlsystem (auch bei Offline Aktivität) Java Basics - Anfänger-Themen 7
U jUnit 5 Test für eine addMethode Java Basics - Anfänger-Themen 18
M monte carlo Algorithmus für 4 gewinnt Java Basics - Anfänger-Themen 12
frager2345 Java Singleton Muster -> Methode für Konstruktor mit Parametern Java Basics - Anfänger-Themen 3
izoards Sortier Algorithmus für Bounding Box Elememte Links nach Rechts und von Oben nach Unten Java Basics - Anfänger-Themen 33
M generate Methode für Streams Java Basics - Anfänger-Themen 6
I Datenmodell für "Tags" Java Basics - Anfänger-Themen 6
Lion.King for-Kontrollstruktur für Pyramide Java Basics - Anfänger-Themen 8
B Mit Countdown Midnestdauer für Teilaufgabenerledigung erzwingen Java Basics - Anfänger-Themen 8
J File length als Prüfwert für Download Java Basics - Anfänger-Themen 5
K Spieleidee gesucht für Informatikprojekt - JAVA (BlueJ)? Java Basics - Anfänger-Themen 15
P Zähler Variable für mehrere Objekte Java Basics - Anfänger-Themen 6
javamanoman Java für Online Banking Java Basics - Anfänger-Themen 12
NadimArazi Wie kann ich eine collision detection für die Paddles in meinem Pong Programm hinzufügen? Java Basics - Anfänger-Themen 4
JordenJost Java ist auch eine Insel für Anfänger Java Basics - Anfänger-Themen 2
P9cman Tipps für Rekursive Aufgaben mit Strings oder allgemein Java Basics - Anfänger-Themen 2
F Suche nach betreuender Person für eine Jahresarbeit der 12. Klasse. Java Basics - Anfänger-Themen 6
I SQL / JPA Query für StartDate und EndDate Java Basics - Anfänger-Themen 1
T getMethode für ein Array Java Basics - Anfänger-Themen 2
Fats Waller Farben mixen für den Hintergrund ? Java Basics - Anfänger-Themen 1
H Suche jemanden für kleine Uni-Abgabe/ mit Vergütung Java Basics - Anfänger-Themen 1
K Für was braucht man die left und right shift operatoren? Was bringen die, also welchen Zweck haben die? Java Basics - Anfänger-Themen 15
N Api nur für Textdatein (.txt) Java Basics - Anfänger-Themen 2
bluetrix Programmieren eines Bots für Zahlen-Brettspiel Java Basics - Anfänger-Themen 9
M Wie kann eine Methode für ein vorhandenes "Array von char" einen Index-Wert zurückliefern? Java Basics - Anfänger-Themen 3
R Ist Java das Richtige für mich? Java Basics - Anfänger-Themen 4
E Mittelquadratmethode für Hexadezimalzahlen Java Basics - Anfänger-Themen 1
P Einfacher regulärer Ausdruck (RegEx) für E-Mail-Adressen Java Basics - Anfänger-Themen 2
Kiki01 Wie würde eine geeignete Schleife aussehen, die die relative Häufigkeit für jeden Charakter in einem Text bestimmt? Java Basics - Anfänger-Themen 3
N Fehler im Code (Aufgabe für Anfänger) Java Basics - Anfänger-Themen 11
O Wie erstelle ich eine Instanz in einer Klasse für die ich die Instanz will? Java Basics - Anfänger-Themen 4
S BubbleSort für ArrayLists Java Basics - Anfänger-Themen 3
T Übungsbuch für Anfänger Java Basics - Anfänger-Themen 3
L Konzept für Quiz Java Basics - Anfänger-Themen 33
D Methoden Plathhalter für Integer in einer Methode Java Basics - Anfänger-Themen 19
B Datentyp für Einzelnes Objekt oder Liste Java Basics - Anfänger-Themen 9
D Welche GUI Library für eine Client Server Chat App Java Basics - Anfänger-Themen 14

Ähnliche Java Themen

Neue Themen


Oben