return wird nicht erkannt?

Lutschbonbon

Neues Mitglied
Hi, ich wollte mal einen Quickselect implementieren und bin dabei auf ein komisches Problem gestoßen. Und zwar wird ein return nicht erkannt, falls das Programm in den IF-Zweig geht.
hier der Code
Java:
public class Quickselect {
    
    public int Quickselect(int[] list, int k){
        int laenge = list.length;
        return sort(list, k, laenge);
    }

    public int sort(int[] list, int k, int laenge){
        int[] lower = new int[100];
        int[] higher = new int[100];
        int i_lower = 0;
        int i_higher = 0;
        int pivo = 0;
        
        //spzialfälle
        if (laenge == 1){
            return list[0];
        }
        if (laenge == 2){
            if (k == 1){
                return (Math.min(list[0], list[1]));
            }
            else{
                System.out.println("Testnachricht");
                return 132541435;
            }
        }
        pivo = list[0];
        for (int i = 1; i <laenge;i++ ){
            if (list[i] <= pivo){
                lower[i_lower] = list[i];
                i_lower++;
            }
            else{
                higher[i_higher] = list[i];
                i_higher++;
            }
                
        }
        if (k <= i_lower){
            sort(lower, k, i_lower);
        }
        else if (k > i_lower+1){
            sort(higher, (k-i_lower-1), i_higher);
        }
        else
            return pivo;
        return 145234;
    }
}

Und zwar bekomm ich die Nachricht: "testnachricht" ausgegeben, aber trotzdem gibt er mir den Wert bei der letzten returnanweisung aus, also 145234 und nicht 132541435...
Wieso wird das return überspringen. Meinem Verständnis nach, sollte es gar nicht möglich sein, für das Programm zu dem letzten return zu kommen, da irgendwo vorher eine If-Abfrage zu einem anderen return führt.
Oder bin ich zu blind und sehe den offensichtlichen Fehler nicht? Aber wie gesagt wundert es mich, dass er die else anweisung aus dem block
Java:
 if (laenge == 2){
            if (k == 1){
                return (Math.min(list[0], list[1]));
            }
            else{
                System.out.println("Testnachricht");
                return 132541435;
            }
        }
ausgibt, aber dann das return überspringt.
 
Zuletzt bearbeitet:
B

Beni

Gast
In Eclipse die Zeile mit dem "println" auswählen, mit ctrl+shift+b einen Breakpoint setzen. Dann das Programm im Debug-Modus starten (Rechtsklick auf das Programm, "Debug As...").
Das Programm wird beim "println" anhalten, und du kannst Schritt für Schritt den Rest des Programmes ausführen (F5, F6 und F7), und rausfinden wann welches return ausgeführt wird.

Meine Vermutung: das ist eine Rekursion, und das "println" wird irgendwo tief in der Rekursion ausgeführt. Die Rückgabewerte von "sort" ignorierst du ja in "sort".
 
N

nillehammer

Gast
Habe den code kopiert und so aufgerufen, dass er im else-Zweig "Testnachricht" landet:
Java:
int result = sort(new int[]{1,3}, 2, 2);
    
    System.out.println(result);
Es wird wie erwartet 132541435 returnt. Ich würde mal darauf tippen, dass Du bei Deinen Tests unbemerkt die Methode mehrfach ausgeführt hast. Und die Ergebnisse nicht vollständig ausgegeben
 

Lutschbonbon

Neues Mitglied
Okay, es lag an den fehlenden returns vor den sort Aufrufen, wenn ich die Teilliste übergebe. War ein ziemlich großer Denkfehler von mir. Aber vielen Dank, dass ihr euch die Mühe gemacht habt, mir zu helfen. :)
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
S Methoden Return Rückgabewert wird nicht übergeben Java Basics - Anfänger-Themen 8
N Ausführung gibt keinen Fehler an, Return wird aber nicht ausgegeben Java Basics - Anfänger-Themen 22
D Methoden Return-Wert wird nicht ausgegeben Java Basics - Anfänger-Themen 3
S Methoden Return Anweisung beendet Methode nicht, stattdessen wird diese zweimal durchlaufen Java Basics - Anfänger-Themen 3
E Warum wird Methode nicht durch return-Befehl beendet? Java Basics - Anfänger-Themen 3
R Nach return() der aufgerufenen Methode wird aufrufende Methode nicht weiter ausgeführt Java Basics - Anfänger-Themen 14
A return funktioniert nicht bzw. wird ignoriert Java Basics - Anfänger-Themen 3
H return wird im Programm angeblich vermisst Java Basics - Anfänger-Themen 2
MiMa Java Doc mehrere Return Parameter Java Basics - Anfänger-Themen 11
A Return in While Schleife Java Basics - Anfänger-Themen 6
J Rekursive Funktion und return statement Java Basics - Anfänger-Themen 3
SUPERTJB return Problem Java Basics - Anfänger-Themen 3
M Warum return die Methode den Wert nicht Java Basics - Anfänger-Themen 5
schredder Strings und reguläre Ausdrücke - Methode mit return string.matches Java Basics - Anfänger-Themen 5
I Return Array Java Basics - Anfänger-Themen 4
Q return Ausgabe Java Basics - Anfänger-Themen 4
javapingu Variablenwerte ändern ohne return Statement? Java Basics - Anfänger-Themen 7
C Ausgabe boolean return ((n==9)||(n==0)); Java Basics - Anfänger-Themen 13
G return 1 + methode Java Basics - Anfänger-Themen 4
H Methode mit Array als Rückgabe This method must return a result of Type int[] Java Basics - Anfänger-Themen 2
JD_1998 Hilfsmethode if return funktioniert nicht Java Basics - Anfänger-Themen 2
J Missing Return Statement Java Basics - Anfänger-Themen 11
T Return einer anderen Methode herausfinden Java Basics - Anfänger-Themen 9
C ArrayList mit return zurückgeben Java Basics - Anfänger-Themen 13
M kann man return in nur einer Methode einsetzen? Java Basics - Anfänger-Themen 7
V return String[] führt zu [Ljava.lang.String;@50675690 Java Basics - Anfänger-Themen 7
K Return in Schleife Java Basics - Anfänger-Themen 4
B Statische Methode return funktioniert nicht. Java Basics - Anfänger-Themen 19
S Missing return Java Basics - Anfänger-Themen 4
das_leon return message Java Basics - Anfänger-Themen 2
C return kann nicht auf variable zugreifen Java Basics - Anfänger-Themen 26
R return: cannot find symbol Java Basics - Anfänger-Themen 2
R Ratespiel mit Return und einer Eingabe Java Basics - Anfänger-Themen 1
Z Return in While-Schleife Java Basics - Anfänger-Themen 7
N Frage zu this, super und return Java Basics - Anfänger-Themen 13
K ArrayList ausgeben mit return Java Basics - Anfänger-Themen 6
M Return statement Java Basics - Anfänger-Themen 4
J-Gallus Ein Getter bekommt eine anderen Type als er Return soll Java Basics - Anfänger-Themen 9
J Variablen Komsiche System.in.read() return-value? Java Basics - Anfänger-Themen 3
M Abbrechen Methode ohne return Java Basics - Anfänger-Themen 3
M Methoden Datei einlesen und als return übergeben. Java Basics - Anfänger-Themen 8
L OOP Return Java Basics - Anfänger-Themen 10
L Erste Schritte Frage zu 'return' Java Basics - Anfänger-Themen 4
J Methoden Rekursive Return Methode Java Basics - Anfänger-Themen 2
W Return statement in Methode nur bei if-clause Java Basics - Anfänger-Themen 3
F Return-Anweisung Java Basics - Anfänger-Themen 2
E Erste Schritte <? super Unterklasse> Return-Typ darf nicht vom Wildcard-Typ sein Java Basics - Anfänger-Themen 5
B OOP Methode mit Array mit return verlassen Java Basics - Anfänger-Themen 8
J Grundsätzliche Frage zu return Types in Methoden Java Basics - Anfänger-Themen 6
G return-wert für eine Methode Java Basics - Anfänger-Themen 1
B Methoden Probleme mit for Schleife und return Java Basics - Anfänger-Themen 5
Q Tastatureingabe direkt nach Eingabe (ohne zwischenzeitliches "Return" o.Ä ) weiterverwenden Java Basics - Anfänger-Themen 1
B Variablen Problem mit return String[] Java Basics - Anfänger-Themen 4
O Per return Run Methode beenden Java Basics - Anfänger-Themen 3
M Arrays als return Value? Java Basics - Anfänger-Themen 2
C Return statement Java Basics - Anfänger-Themen 10
T Boolean Missing return Statement?! Java Basics - Anfänger-Themen 2
Z Methoden return nullprüfung Java Basics - Anfänger-Themen 7
O Java return in Schleife Java Basics - Anfänger-Themen 4
K Was macht hier genau return? Java Basics - Anfänger-Themen 2
G Methoden Was bedeutet return in einer Methode Java Basics - Anfänger-Themen 5
Y Warum void statt Datentyp + return Java Basics - Anfänger-Themen 4
K Variablen RETURN in Case-Switch / This method must return a result of type Item Java Basics - Anfänger-Themen 4
K Erste Schritte "return" Problem bei Rekursion Java Basics - Anfänger-Themen 8
R If Verschachtelung und return; Java Basics - Anfänger-Themen 4
M Frage zum return; Befehl Java Basics - Anfänger-Themen 1
S try-catch - Variablen werden nicht an return übergeben Java Basics - Anfänger-Themen 3
C Einige Anfängerfragen (Return-Wert, Exception...) Java Basics - Anfänger-Themen 11
S Methoden Return Java Basics - Anfänger-Themen 8
T return-Wert verwenden? Java Basics - Anfänger-Themen 12
T Return eines Int-Werts? Java Basics - Anfänger-Themen 3
W return-Anweisung gibt nichts aus Java Basics - Anfänger-Themen 5
R Return in If Java Basics - Anfänger-Themen 10
G array return methode Java Basics - Anfänger-Themen 10
J Regex mit Return Java Basics - Anfänger-Themen 3
M Variablen return-array klonen Java Basics - Anfänger-Themen 3
A Methode mit Array als Param --> return Array --> Fehler Java Basics - Anfänger-Themen 3
S Zeichen einlesen ohne Return? Java Basics - Anfänger-Themen 19
P Compiler-Fehler Boolean: Missing Return Statement Java Basics - Anfänger-Themen 4
S probleme mit der return anweisung Java Basics - Anfänger-Themen 20
V Erste Schritte Return ohne Argument Java Basics - Anfänger-Themen 6
I Methoden Missing return statement; Intervallschachtellung Java Basics - Anfänger-Themen 12
S Frage zu Vererbung und return. Java Basics - Anfänger-Themen 4
R return (mehrere floats) Java Basics - Anfänger-Themen 11
E Return String Java Basics - Anfänger-Themen 10
P Methoden Methode ohne return abbrechen? Java Basics - Anfänger-Themen 12
I Return Befehl in Methode Java Basics - Anfänger-Themen 13
M Problem mit boolean. Return nicht erkannt Java Basics - Anfänger-Themen 10
P Return aus For-Schleife Java Basics - Anfänger-Themen 19
S return in GUI ? Java Basics - Anfänger-Themen 12
M This method must return a result of type int Java Basics - Anfänger-Themen 13
F Erste Schritte return (char)toUnsignedInt(value) Java Basics - Anfänger-Themen 2
A Falscher Return-Wert Java Basics - Anfänger-Themen 2
M missing return statement?! Java Basics - Anfänger-Themen 4
L Return Fragen Java Basics - Anfänger-Themen 4
I Null als return obwohl datensatz existiert Java Basics - Anfänger-Themen 12
S this method must return a result of type double Java Basics - Anfänger-Themen 2
V Problem mit return Java Basics - Anfänger-Themen 7
K Return Problem Java Basics - Anfänger-Themen 3
M Fragen zu Methoden (void/return), Übergabe von Parametern Java Basics - Anfänger-Themen 3

Ähnliche Java Themen

Neue Themen


Oben