Was passiert in dieser Methode?

bob651

Aktives Mitglied
HI, ich implementiere imMo einen Mergesort und habe jetzt die Methode mischen:
Java:
 private void mischen(int links, int mitte, int rechts) {
//methode mischt alle arrays
        for (int i = links; i <= rechts; i++) {    //solange rechts größer/gleich links -->links erhöhen
            zsmfugen[i] = array[i];
        }
      
        int i = links;
        int j = mitte + 1;
        int k = links;
     
      
        while (i <= mitte && j <= rechts) {
            if (zsmfugen[i] <= zsmfugen[j]) {
                array[k] = zsmfugen[i];
                i++;
            } else {
                array[k] = zsmfugen[j];
                j++;
            }
            k++;
        }
        while (i <= mitte) {
            array[k] = zsmfugen[i];
            k++;
            i++; }}
Also könntet ihr mir sagen, was genau gemacht wird? Also z.B warum ist int i und k beide =links ?
Und was soll die while Schleife bringen?
Ich habe es so verstanden, dass
"Solange i <= Mitte ist und rechts <= mitte"
"Wenn usmfugen <= zsmfugen[j] ist, soll der wert von array[k] in zsmfugen gespeichert werden"
"dann soll i erhöht werden"

Aber warum wird i erhöht. Blicke nicht so ganz durch.
Wäre cool wenn ihr mir paar Tipps geben könntet.
 
Zuletzt bearbeitet von einem Moderator:

Meniskusschaden

Top Contributor
Also z.B warum ist int i und k beide =links ?
i durchläuft das Array von der ersten Position bis zur Mitte, j durchläuft es von der Mitte bis zum Ende und k von der ersten bis zur letzten Position.
Und was soll die while Schleife bringen?
Welche der beiden? Die erste wird durchlaufen, solange noch keine der beiden Array-Hälften vollständig durchlaufen wurde.
Danach wird mit der zweite while-Schleife noch der Rest der ersten Array-Hälfte durchlaufen. Da müsste sicher noch eine dritte Schleife folgen, um den Rest der zweiten Array-Hälfte zu verarbeiten.

Am besten machst du mal einen Schreibtischtest. Dann sieht man ganz gut, was da vor sich geht.
 

bob651

Aktives Mitglied
Hm, also verstehe noch nicht was die while schleife bringt. Also wann sie durchläuft weiß ich, aber nicht was sie macht. z.B
array[k}= zsmfugen[i);
i++:
was genau macht es?
Ich hab in der Theorie verstanden, wie der Algorithmus geht, also durch 2 teilen, zsmfügen usw.

also ich habe ja 2 int arrays (array, zsmfugen), dann habe ich noch einen inputarray
Code:
private int[] array;
    private int[] zsmfugen;
    private int lange;

public void zerlegen(int inputArray[]) {
        this.array = inputArray;
        this.lange = inputArray.length;
        this.zsmfugen = new int[lange];
        mergesort(0, lange - 1);
    }

bringt mich alles iwie durcheinander, hoffe kannst mir da noch weiterhelfen :)
 

Meniskusschaden

Top Contributor
Hm, also verstehe noch nicht was die while schleife bringt. Also wann sie durchläuft weiß ich, aber nicht was sie macht. z.B
array[k}= zsmfugen[i);
i++:
was genau macht es?
Du kannst dir i, j und k als Zeiger auf drei Mengen vorstellen: die beiden bereits in sich sortierten Teilarrays (links bis mitte und mitte+1 bis rechts) und das noch nicht sortierte Gesamtarray.
In der ersten Schleife läufst du mit den Zeigern i und j so durch die beiden Teilarrays, dass du jeweils das kleinere der beiden Elemente auf die i und j zeigen an die Position k des Gesamtarrays kopierst. Nach dem Kopieren eines Elementes werden k und entweder i oder j um 1 erhöht und die nächste Schleifeniteration beginnt.
Irgendwann wurde entweder das erste oder das zweite Teilarray vollständig in das Gesamtarray kopiert. Das ist der Zeitpunkt, an dem die erste Schleife endet. Dann sind aber noch in paar Elemente in dem anderen Teilarray übrig.
Angenommen das zweite Teilarray wurde komplett kopiert (j). Dann zeigt i noch auf die erste Position des ersten Teilarrays, die noch nicht kopiert wurde und k auf die nächste freie Position des Gesamtarrays. Die zweite Schleife kopiert diese Elemente nun in das Gesamtarray und muß deshalb natürlich in jeder Iteration i und k erhöhen, damit jeweils das nächste Element des ersten Teilarrays in die nächste Position des Gesamtarrays kopiert wird.
Für den Fall, dass in der ersten Schleife das erste Teilarray komplett verarbeitet wurde, muß man das analog auch für das zweite Teilarray realisieren.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
T Kann mir jemand wörtlich erklären, was in dem Code genau passiert? Java Basics - Anfänger-Themen 1
N Was Passiert mit dem Namen einer Variable, wenn man diese einer Liste Hinzufügt Java Basics - Anfänger-Themen 16
S Operatoren i=i++; Was passiert hier? Java Basics - Anfänger-Themen 21
N Enum Typen, was passiert intern mit ihnen? Java Basics - Anfänger-Themen 2
N Was passiert wenn wir Daten auf der Festplatte abspeichern wollen? bzgl. BufferStreams Java Basics - Anfänger-Themen 9
S Unklarer Code (was passiert hier?) Java Basics - Anfänger-Themen 1
T Kann mir jemand sagen, was bei folgender for-Schleife passiert? Java Basics - Anfänger-Themen 1
V Was passiert in dem Programm? Java Basics - Anfänger-Themen 3
W Was passiert mit Objekten die nicht in Objektvariablen initialisiert werden ? Java Basics - Anfänger-Themen 3
T boolean, was passiert hier? Java Basics - Anfänger-Themen 4
G Was passiert bei einem Overflow von zwei Integer Java Basics - Anfänger-Themen 6
B Nichts passiert... Java Basics - Anfänger-Themen 4
C Klassen BubbleSort was passiert mit dem Index ? Java Basics - Anfänger-Themen 2
J Was passiert hier? Java Basics - Anfänger-Themen 6
D KeyListener, nichts passiert Java Basics - Anfänger-Themen 6
B Was passiert, wenn eine konkrete Klasse von generische Klasse erbt? Java Basics - Anfänger-Themen 14
F festlegen, was beim schließen des fensters passiert Java Basics - Anfänger-Themen 12
E DeSerialize von verändertem Object, was passiert? Java Basics - Anfänger-Themen 4
-horn- Was passiert, wenn Zähler über Integer Max läuft? Java Basics - Anfänger-Themen 9
G Was passiert mit eine Methode bei einer Instanz Java Basics - Anfänger-Themen 13
R Deklaration: was passiert da? Java Basics - Anfänger-Themen 3
G Was passiert "at compile time" Java Basics - Anfänger-Themen 3
M 2 Fragen: Vergleich, aber wie? Was passiert in diesem Teil? Java Basics - Anfänger-Themen 18
G Abstrakte Klasse (was passiert hier) Java Basics - Anfänger-Themen 3
G pow(double,double) was passiert bei pow(double,int) Java Basics - Anfänger-Themen 6
M Migration JUnit 3.8 -> 4.0, was passiert mit Testsuites? Java Basics - Anfänger-Themen 3
ohneInformatik; For Schleife. Was macht dieser Code?? Java Basics - Anfänger-Themen 5
K Warum zeigt dieser reguläre Ausdruck true an? Java Basics - Anfänger-Themen 1
N Was bedeutet dieser Fehler Java Basics - Anfänger-Themen 2
Leo0909 Ich brauche Hilfe bei dieser Aufgabe Java Basics - Anfänger-Themen 2
P Was bedeutet dieser Fehler? Java Basics - Anfänger-Themen 31
P Nutzer entscheiden lassen, wie viele Zahlen dieser in ein Array eingeben möchte. Java Basics - Anfänger-Themen 6
M Warum dürfen Objekte einer Klasse auf statische Variablen dieser Klasse referenzieren? Java Basics - Anfänger-Themen 10
Bluedaishi Hilfe beim erklären dieser Methode Java Basics - Anfänger-Themen 5
S Warum dieser Fehler? Java Basics - Anfänger-Themen 1
B Datum in dieser Range SQL? Java Basics - Anfänger-Themen 3
R Dieser Code sagt mir nichts... Java Basics - Anfänger-Themen 4
D Erste Schritte Lösen dieser Aufgabe, Hilfe! Java Basics - Anfänger-Themen 12
J Brauche Hilfe bei dieser Aufgabe Java Basics - Anfänger-Themen 3
F Wieso wird dieser Befehl nicht ausgeführt? (Anfänger) Java Basics - Anfänger-Themen 2
M Frage, wie dieser Code funktioniert, bzw. weshab er bei mir nicht funktioniert Java Basics - Anfänger-Themen 4
L Hilfe! Was macht dieser Code? Java Basics - Anfänger-Themen 1
S Erste Schritte Was bedeutet dieser Code? Java Basics - Anfänger-Themen 2
D Erste Schritte Was bedeutet dieser Code? Java Basics - Anfänger-Themen 23
V Operatoren Warum kommt nicht das gewünschte Ergebnis dieser Operation? Java Basics - Anfänger-Themen 3
R Gibt es Eine einfache Programierung dieser Methoden Java Basics - Anfänger-Themen 8
G Lastet dieser Code den Arbeitsspeicher eines Handys aus? Java Basics - Anfänger-Themen 7
Nicole1989 Was Bewirkt dieser Java Code? Java Basics - Anfänger-Themen 4
B Summe aller Zahlen von 1 bis zu dieser Zahl (ohne while oder for schleife) Java Basics - Anfänger-Themen 4
J Wo liegt nur an dieser einfachen Bedingung mein Fehler? Java Basics - Anfänger-Themen 8
A Wieso funktioniert dieser Timer nicht?? Java Basics - Anfänger-Themen 3
C Warum funktioniert dieser Code nicht? Java Basics - Anfänger-Themen 2
A Lässt sich dieser Ausdruck irgendwie einfacher schreiben? Java Basics - Anfänger-Themen 4
H Geht dieser Code noch einfacher (try catch finally) Java Basics - Anfänger-Themen 7
P Geht dieser Code noch einfacher? Java Basics - Anfänger-Themen 16
G Bitte um Erklärung dieser einer Zeile Java Basics - Anfänger-Themen 5
F OOP Warum funktioniert dieser Regex? Java Basics - Anfänger-Themen 15
S Was bedeutet dieser ausdruck? Java Basics - Anfänger-Themen 9
P Unterschied dieser 2 code Zeilen Java Basics - Anfänger-Themen 12
StrikeTom Was ist an dieser einfachen funktion falsch? Java Basics - Anfänger-Themen 5
M Wieso funktioniert dieser simple Code nicht? Java Basics - Anfänger-Themen 9
M prozess starten und warten bis dieser sich beendet Java Basics - Anfänger-Themen 3
P Was macht dieser Source code? Java Basics - Anfänger-Themen 5
S OOP Wie muss meine Klasse zu dieser main aussehen? Java Basics - Anfänger-Themen 5
0 Was bedeutet dieser Generic-code? Java Basics - Anfänger-Themen 3
H Wie so ein Exception in dieser HashMap? Java Basics - Anfänger-Themen 7
K Was wird in dieser Frage gemeint ? Java Basics - Anfänger-Themen 15
V Wie und wieso geht dieser Methodenaufruf? Java Basics - Anfänger-Themen 2
G Versteh nicht was an dieser If-Anweisung falsch ist Java Basics - Anfänger-Themen 2
S Ursache dieser Fehlermeldung (access dinied) Java Basics - Anfänger-Themen 3
A Was macht dieser Prgrammteil? Java Basics - Anfänger-Themen 2
B Warum hat dieser einfache Algorithmus lineare Laufzeit? Java Basics - Anfänger-Themen 3
B Wieso funktioniert dieser Vergleich nicht? Java Basics - Anfänger-Themen 3
A Welche dieser Schleifen im TableCellRendererist effizienter? Java Basics - Anfänger-Themen 18
A Was ist an dieser Datum-Methode falsch? Java Basics - Anfänger-Themen 5
G Was macht dieser Code? Java Basics - Anfänger-Themen 3
J Was sagt mir dieser Ausdruck? Java Basics - Anfänger-Themen 9
S Brauche hilfe zu dieser AUfgabe Java Basics - Anfänger-Themen 4
M Was ist an dieser case-Anweisung falsch? Java Basics - Anfänger-Themen 2
R Was bewirkt dieser Code? Java Basics - Anfänger-Themen 6
T Rekursive Methode Java Basics - Anfänger-Themen 13
Ü Methode soll Quadrat aus der Summer zurückgeben Java Basics - Anfänger-Themen 10
P Objekt einer Methode eines anderen Objektes übergeben Java Basics - Anfänger-Themen 5
Leyla Spezifischte Methode Java Basics - Anfänger-Themen 16
M Methode zielnah zeigt das gewünschte Ausgabe nicht an Java Basics - Anfänger-Themen 3
L Variablenwerte aus einer Methode übergeben Java Basics - Anfänger-Themen 2
T Methode soll etwas ausrechnen und zurückgeben (klappt nd) hat wer eine Idee? Java Basics - Anfänger-Themen 11
P Main Methode scheint Constructor aufzurufen, ohne dass es so gecoded ist Java Basics - Anfänger-Themen 2
T Aufruf der Methode einer Oberklasse, wenn sie in der Unterklasse überschrieben ist. Polymorphie. Java Basics - Anfänger-Themen 2
C Zugriff auf Methode Java Basics - Anfänger-Themen 2
M Datentypen While-Schleife eine Java Methode erstellen Java Basics - Anfänger-Themen 3
T Methode akzeptiert String nicht Java Basics - Anfänger-Themen 18
M Methode sperren bis ein Kriterium erfüllt wurde Java Basics - Anfänger-Themen 3
D Switch Case Methode aufrufen Java Basics - Anfänger-Themen 3
C Unbekannte Methode add bei Klasse die JTree erweitert Java Basics - Anfänger-Themen 14
M methode aufrufen ohne parameter Java Basics - Anfänger-Themen 1
marcelnedza Finde meinen Fehler in einer Methode nicht, Java Karol Java Basics - Anfänger-Themen 15
monsterherz einfache Methode mit Fehler den ich nicht finde Java Basics - Anfänger-Themen 21
Ostkreuz Wieso wird die Methode nochmal aufgerufen? Java Basics - Anfänger-Themen 5
G Variable aktualisiert sich nicht in rekursiver Methode Java Basics - Anfänger-Themen 4

Ähnliche Java Themen

Neue Themen


Oben