Probleme bei Ausgabe von rekursiver Methode (List)

Siebenkern

Mitglied
Moin!

Ich habe ein kleines Problem mit einem Programm.
Ein Fehler, der meiner Meinung nach nicht auftreten sollte.
und zwar wird mir folgendes angezeigt:

"Exception in thread "main" java.lang.Error: Unresolved compilation problem:
The operator + is undefined for the argument type(s) List<Integer>, List"


Und zwar hier:

Java:
static List zip(List<Integer> vs, List<Integer> ws){
		
		List<Integer> intern = new LinkedList<Integer>();
		if(vs.isEmpty() && ws.isEmpty()) return null;
		if(ws.isEmpty()){ intern.add(vs.remove(0)); return zip(vs, ws);}
		if(vs.isEmpty()){ intern.add(ws.remove(0)); return zip(vs, ws);}
		intern.add(vs.remove(0));
		intern.add(ws.remove(0));
		return intern + zip(vs, ws);  //hier wird der Fehler angezeigt.

Muss ich das "+"-Zeichen irgendwie noch einmal genau definieren?
 

Tiding

Aktives Mitglied
Naja,
intern gibt dir List<Integer> zurück und
zip(vs, ws) gibt dir List zurück.

Die Exception sagt dir, dass du List + List<Integer> nicht machen darfst.

Wo liegt jetzt genau das Problem? ???:L

Könnte ja passieren, dass du dann String[] + int rechnest...
 

Siebenkern

Mitglied
Das "+" war gedacht, damit die Methode sich selbst wieder aufruft, also rekursiv ist.
Auf diese Weise sollen die Listen vs und ws zu der Liste intern verschmelzen.
Was müsste ich da am besten ändern, damit dies geschieht?
 

njans

Top Contributor
Java:
return intern .addAll(zip(vs, ws));

Das müsstest du ändern. Der + Operator hat keine Funktion auf Listen in Java.
 

Siebenkern

Mitglied
Das erzeugt bei mir nur einen anderen Fehlercode, weil die Ausgabe der Liste plötzlich zu Boolean wird.
("Type mismatch: cannot convert from boolean to List")

Aber vielleicht habe ich es auch einfach nur dumm erklärt:

Ich wollte, dass die Listen vs (z.B.: 1, 3, 5, 7) und ws(z.B.: 2, 4, 6, 8) zu der Liste intern(1, 2, 3, 4, 5, 6, 7, 8) verschmelzen.

Deshalb wollte ich eine Möglichkeit finden, dass zwar schon einmal die ersten zwei Objekte der Liste intern ausgegeben werden, aber die Methode sich danach noch einmal selbst wieder aufruft, um auch die restlichen Objekte in die Liste zu übernehmen und auszugeben.
 

Tiding

Aktives Mitglied
Ahhhh, jetzt verstehe ich was das da oben machen soll! :bloed: :D

Da ich nix besseres zu tun hab, schau ich mal was meinem Köpfchen so alles dazu einfällt ^^
 

Tiding

Aktives Mitglied
Java:
    static List verschmelzen(List<Integer> List1, List<Integer> List2){
    	if(List1 != null) List1.addAll(List2);
    	else return List2;
    	return List1;
    }
Das ganze noch ordnen lassen und fertig.

ich weiß jetzt nicht; musst du das ganze rekursiv lösen? Weil die Methode addAll macht ja genau das was du willst :eek:!
 
Zuletzt bearbeitet:

rme

Top Contributor
Durch [c]addAll[/c] wird [c]intern[/c] modifiziert - du kannst doch einfach danach [c]return intern;[/c] machen, oder nicht?

Darf ich fragen, an welcher Uni man gezwungen wird, die Wunder der funktionalen Programmierung ausgerechnet in Java zu lernen? Die Sprache ist dafür doch denkbar ungeeignet und man wird eher demotiviert, jemals wieder an Rekursion zu denken, sobald man damit durch ist..
 

Tiding

Aktives Mitglied
Was im üprigen dein Problem angeht:

ja der Rückgabetype von add ist boolean, aber das Element wird der Liste mit Aufruf dieser Methode zugefügt, also erst die Methode aufrufen und dann die neue Liste, die nun ein Objekt mehr hat zurückgeben.
 

Siebenkern

Mitglied
Also erst mal vielen Dank, dass ihr euch alle die Mühe macht :)

Ich muss diese Aufgabe unbedingt rekursiv lösen. Wichtig wäre auch, dass ich dabei nicht im nachhinein ordne, sondern das von alleine in diese Reihenfolge gebracht wird.

Liste a (a, a, a, a, a, a)
Liste b (b, b, b, b, b, b)
--> (a, b ,a ,b ,a ,b,...)

Deswegen suche ich nach einem Weg, dass nicht nur die ersten beiden Elemente eingefügt werden, sondern beide Listen so abgearbeitet werden.

Achja, ich studiere an einer Fachochschule. Vielleicht liegt es ja daran :D
 

Tiding

Aktives Mitglied
Hilft dir das evtl. weiter?
Java:
    static List<Integer> zip(List<Integer> intern, List<Integer> list1, List<Integer> list2){
    	if(list1.isEmpty() && list2.isEmpty()) return intern;
        if(list2.isEmpty()){
        	intern.addAll(list1);
        	return intern;
        }
        if(list1.isEmpty()){
        	intern.addAll(list2);
        	return intern;
        }
        intern.add(list1.get(0));
        intern.add(list2.get(0));
        list1.remove(0);
        list2.remove(0);
        return intern = zip(intern, list1, list2);  
    }
 

Tiding

Aktives Mitglied
anders, sprich ohne eine äußere Liste, in die du die jeweiligen Elemente einfügen kannst, fällt mir nichts ein, wobei es noch fraglich ist, ob das überhaupt möglich ist. ???:L :bahnhof:
 

Siebenkern

Mitglied
Also erst mal ein dickes Danke, weil du mir heute ganz gut geholfen hast.
Aber in der Aufgabenstellung ist leider explizit gefordert, dass dort die Ausgabe so ist, wie ich sie in dem vorletzten Post beschrieben hatte. Daher bringt mich das auch nicht weiter.
Aber ich kann ja morgen, wenn wir die Lösungen bekommen haben, zeigen, was gefordert war.
Ich häng da schon seit stunden dran und weiß einfach nicht weiter, aber scheinbar bin ich nicht der Einzige.

Also gut, dann schon mal eine gute Nacht und bis morgen! :)
 

Tiding

Aktives Mitglied
Gute Nacht!
Ja, sobald man dann die Lösung sieht, denkt man sich nur: Warum bin ich denn darauf nur nicht gekommen :D! :bloed:
 

Tiding

Aktives Mitglied
Java:
    static List<Integer> zip(List<Integer> list1, List<Integer> list2){
    	List<Integer> intern = new LinkedList<Integer>();
    	if(list1.isEmpty() && list2.isEmpty()) return intern;
        if(list2.isEmpty()){
        	intern.addAll(list1);
        	return intern;
        }
        if(list1.isEmpty()){
        	intern.addAll(list2);
        	return intern;
        }
        intern.add(list1.get(0));
        intern.add(list2.get(0));
        list1.remove(0);
        list2.remove(0);
        intern.addAll(zip(list1, list2));
        return intern;  
    }

Garnichtmal so anders! :bloed: :popcorn: :D
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
K Probleme bei der Ausgabe - komme nicht weiter :/ Java Basics - Anfänger-Themen 15
hdi formatierte ausgabe -> probleme mit tabulator abstand Java Basics - Anfänger-Themen 3
A Probleme mit Ausgabe von Werten Java Basics - Anfänger-Themen 7
A Probleme bei Ausgabe (array) Java Basics - Anfänger-Themen 2
D Rekursions Probleme / frage Java Basics - Anfänger-Themen 4
P JDK installieren Probleme bei der Java-Installation Java Basics - Anfänger-Themen 8
C Probleme mit Byte konvertieren nach int Java Basics - Anfänger-Themen 10
P Probleme mit NetBeans: Wie lässt sich jar. Datei an einem MacBook öffnen Java Basics - Anfänger-Themen 21
I Projekte in IDE untereinander sharen / Probleme beim Build Java Basics - Anfänger-Themen 8
MiMa Probleme mit Datentyp long ?? Java Basics - Anfänger-Themen 2
T Probleme beim Import eines Git-Repos Java Basics - Anfänger-Themen 2
Jxhnny.lpz TicTacToe Spiel vs Computer. (Probleme) Java Basics - Anfänger-Themen 7
B Quiz mit RMI Probleme mit RMI start Java Basics - Anfänger-Themen 4
httprt Probleme bei dem erstellen von leveln in meinem Spiel Java Basics - Anfänger-Themen 2
berserkerdq2 Habe eine Klasse, welche public ist, diese hat eine public Methode, die nicht static ist. Wenn ich nun versuche aufzurufen Probleme? Java Basics - Anfänger-Themen 8
V Probleme Guessing Game Java Basics - Anfänger-Themen 8
hebein PDF Ausdruck auf Drucker - Probleme mit Format Java Basics - Anfänger-Themen 17
R JMenu/JMenuItem Probleme Java Basics - Anfänger-Themen 2
B Static vs non static und Probleme daraus Java Basics - Anfänger-Themen 13
J Probleme mit dem Debugger Java Basics - Anfänger-Themen 4
I Probleme mit OutputStream - Datei lässt sich nicht öffnen Java Basics - Anfänger-Themen 4
J Probleme mit Kompilierung Java Basics - Anfänger-Themen 11
B Probleme mit Zugriff auf Dateisystem Windows 10 ( jFileChooser) Java Basics - Anfänger-Themen 17
W Objekte über Scanner Input; ToString Probleme... Java Basics - Anfänger-Themen 4
C Probleme mit paintComponent Java Basics - Anfänger-Themen 13
P Probleme mit JUnit-Tests, es kommt was anderes raus als bei manuellen Tests Java Basics - Anfänger-Themen 5
E JavaFX Editor Probleme mit der Zwischenablage Java Basics - Anfänger-Themen 12
C Probleme mit dem Erstellen und Importieren von Packages Java Basics - Anfänger-Themen 6
3 OOP erste Versuche, OOP zu verstehen. Probleme mit gettern und settern Java Basics - Anfänger-Themen 4
R Erste Schritte Probleme bei 2D Spielfeld, mit einzufügender "Person" Java Basics - Anfänger-Themen 5
P Probleme bei der Installation von JavaFX Java Basics - Anfänger-Themen 3
S Mehrere Probleme im Code Java Basics - Anfänger-Themen 7
D Probleme mit JFrame und der Größe Java Basics - Anfänger-Themen 8
Dimax String Probleme Java Basics - Anfänger-Themen 12
N Probleme beim printen von Arrays durch for Schleife Java Basics - Anfänger-Themen 3
Splayfer Java Array Probleme Java Basics - Anfänger-Themen 3
J Probleme bei IllegalArgumentException "werfen". Java Basics - Anfänger-Themen 1
X Probleme im Umgang mit PriorityQueue Java Basics - Anfänger-Themen 75
D Probleme mit dem Windowbuilder und JComboBox Java Basics - Anfänger-Themen 2
M Regex Probleme (mal wieder) Java Basics - Anfänger-Themen 3
tom.j85 TicTacToe - probleme beim Casten Java Basics - Anfänger-Themen 6
J Probleme mit Vererbung Java Basics - Anfänger-Themen 4
X Probleme mit Übungsaufgaben zu Zahlentypen Java Basics - Anfänger-Themen 4
G Probleme bei Aufgabe Java Basics - Anfänger-Themen 12
P Erste Schritte Probleme mit dem Programmieren Java Basics - Anfänger-Themen 12
B Probleme bei einer Aufgabe Java Basics - Anfänger-Themen 19
Franzi1001 Probleme mit Eclipse Java Basics - Anfänger-Themen 7
T Probleme bei Installation von JDK Java Basics - Anfänger-Themen 2
C Probleme mit String-Vergleich Java Basics - Anfänger-Themen 4
C Probleme bei Regex Java Basics - Anfänger-Themen 9
V Probleme mit Arrays Java Basics - Anfänger-Themen 8
D Kleine Probleme mit Split-Befehlen Java Basics - Anfänger-Themen 5
T Probleme mit Strings Java Basics - Anfänger-Themen 6
G Probleme bei Frame aufgaben Java Basics - Anfänger-Themen 6
N Probleme mit dem ActionListener Java Basics - Anfänger-Themen 4
D Probleme beim Kompelieren mache ich etwas falsch ? Java Basics - Anfänger-Themen 3
L Probleme mit Java Java Basics - Anfänger-Themen 3
S Probleme mit abspielen einer .wav Datei Java Basics - Anfänger-Themen 2
J Probleme bei der Umwandlung einer Farbe von Hex zu RGB Java Basics - Anfänger-Themen 8
K Probleme beim Programm schreiben - Lesen von Dateiinhalten -zaehlen von Wörtern/ Buchstaben Java Basics - Anfänger-Themen 4
M Probleme beim aktualisieren eines JPanels Java Basics - Anfänger-Themen 7
J Probleme beim Array ausgeben Java Basics - Anfänger-Themen 4
M Probleme bei rekursiver Zuordnung Java Basics - Anfänger-Themen 1
I Probleme mit 2 dimensionale Arrays Java Basics - Anfänger-Themen 3
H Best Practice View probleme Java Basics - Anfänger-Themen 2
B Probleme mit Kreisberechnung Java Basics - Anfänger-Themen 15
E Probleme mit Scanner Java Basics - Anfänger-Themen 4
J Eclipse Export Probleme Java Basics - Anfänger-Themen 25
M Probleme beim verwenden von Packages Java Basics - Anfänger-Themen 6
D Probleme mit der Übergabe einer BorderPane Java Basics - Anfänger-Themen 2
J Interface Probleme bei der Implementierung Java Basics - Anfänger-Themen 1
BlueFox Tabelle in der Konsole ausgeben - Probleme Java Basics - Anfänger-Themen 1
G Methoden Probleme beim Methodenaufruf Java Basics - Anfänger-Themen 2
V Klassen ObjectInputStream ->ReadObject Probleme Java Basics - Anfänger-Themen 5
P Probleme mit der Do-Schleife Java Basics - Anfänger-Themen 2
F Erste Schritte Compiling Probleme Java Basics - Anfänger-Themen 13
S Neuling und Probleme bei Schulaufgabe Java Basics - Anfänger-Themen 5
J Anfänger: ActionListener und ProcessBuilder machen Probleme Java Basics - Anfänger-Themen 6
S Erste Schritte 2D Grafik Probleme mit KeyListener. Java Basics - Anfänger-Themen 18
M Array mit eigenem Datentyp probleme beim übergeben Java Basics - Anfänger-Themen 6
M Probleme mit Eclipse Java Basics - Anfänger-Themen 20
G Probleme beim casten von double zu int Java Basics - Anfänger-Themen 3
E 2 Probleme - Datum & private finale Variablen Java Basics - Anfänger-Themen 5
S Compiler-Fehler javac hat Probleme mit Paketen unter OSX Java Basics - Anfänger-Themen 2
J Probleme beim schreiben von Dateien Java Basics - Anfänger-Themen 5
B Variablen Probleme mit Eclipse Java Basics - Anfänger-Themen 6
H Mouse- und KeyListener Probleme? Java Basics - Anfänger-Themen 5
A Probleme beim zykl. aktulisieren von Daten in JTable Java Basics - Anfänger-Themen 3
I Probleme bei Verzeichnissanalyse Java Basics - Anfänger-Themen 12
F Probleme mit privaten Klassen (abstrakten Klassen) Java Basics - Anfänger-Themen 1
H Probleme mit Klassen...oder: Eine Uhr Java Basics - Anfänger-Themen 9
G Probleme mit Konsole Java Basics - Anfänger-Themen 4
S Probleme mit GamGrid Spiel-Erstellung => Actor reagiert nicht auf Tastatur Java Basics - Anfänger-Themen 2
G Probleme mit Eclipse oder der URL Klasse Java Basics - Anfänger-Themen 5
W Verständnis Probleme bei der while-Schleife und continue Java Basics - Anfänger-Themen 21
M Probleme mit Anzeigen von String in GUI und if-Anweisung Java Basics - Anfänger-Themen 9
T Konstruktor Probleme Java Basics - Anfänger-Themen 3
W Methoden Probleme mit der Scanner Methode Java Basics - Anfänger-Themen 2
F Ja Nein Abfrage und andere Probleme Java Basics - Anfänger-Themen 5
L If Anweisung mit ArrayList Probleme Java Basics - Anfänger-Themen 6

Ähnliche Java Themen

Neue Themen


Oben