Java Listen und Generics

BlitzKrieg42

Mitglied
Hallo,
ich habe folgendes Problem. Ich studiere Elektrotechnik und habe große Probleme mit Java. Die Java Klausur schreibe ich zum 2ten Mal. Ich kann die Algorithmen sehr gut verstehen , nur wenn ich Java Codes schreiben möchte komme ich sehr häufig durcheinander wegen while-,if... schleifen. Ein Tipp wäre sehr nett.
Folgende Aufgabe kam in der letzten Klausur:
gegeben ist eine einfach verketete Liste . Ich muss eine Methode remove(int index) schreiben ,die die Daten an der Stelle "index" zurückgibt und löscht. Ich habe mir Folgendes überlegt:
ich definiere eine Zahl int k. und definiere ein Verweis curr (steht für current) curr fängt ab head an. wenn curr.next , dann k++ . Falls k = index muss müssen die Daten an der Stelle index zurückgeliefert und dann gelöscht. Nun die Frage ist: wie schreibe ich das richtig in Java?:rtfm:
Ich hoffe auf eine schnelle Antwort.
Liebe Grüße
 

diggaa1984

Top Contributor
poste doch mal code wie du ihn schreiben würdest .. das musst du ja schliesslich in der klausur auch können .. den korrigieren wir gerne, falls nötig .. und eventuell tauchen bei dir ja noch gleich andere fragen auf
 

Landei

Top Contributor
Ziemlich unvollständiges Beispiel:
Java:
class Liste {

    Knoten anfang;

    public void remove(int index) {
        if (index == 0) {  //Speziallfall Listenanfang
            if(anfang != null) {
                anfang = anfang.nachfolger;
            } 
        } else {
           Knoten curr = anfang; //Am Anfangsknoten beginnen
           for(int i = 0; i < index-1 && curr != null; i++) {
              curr = curr.nachfolger; //bis zum *Vorgänger* des zu löschenden Knotens gehen 
           }
           if(curr != null && curr.nachfolger != null) {
                //dessen Referenz so manipulieren, dass er auf den übernächsten Knoten zeigt
                curr.nachfolger = curr.nachfolger.nachfolger;  
           }
        }
    }

    static class Knoten(){
         String wert;
         Knoten nachfolger; 
    }
}

Der Code ignoriert allerdings alle Fälle, in denen die Liste zukurz ist, je nach Aufgabenstellung musst du da eventuell stattdessen eine Exception werfen.
 
Zuletzt bearbeitet:

BlitzKrieg42

Mitglied
Danke für die schnelle Antwort.
Code:
class List <Daten>{
private ListEl head;
private ListEl curr;
private ListEl prev;
private class List{
private Daten arg;
private Daten value;
private ListEl next;
ListEl(Daten arg, Daten value,ListEl next){
this.arg=arg;
this.value=value;
this.next=next;
}
}// bisher wurde alles kopiert , da das gegeben wird. Ab hier schreibe ich selber.

private void remove (int index){
if (index==0){
system.out.println(this.head.arg);
this.head=this.head.next;
}else{int k=1;
this.prev=this.head;
this.curr=this.head.next;
while(k!=index){
curr=curr.next;
prev=prev.next;
k++;}
if(this.curr!=null){
system.out.println(this.curr.arg);
this.prev.next=this.curr.next;
}}}

Danke für eure Hilfe.
 
Zuletzt bearbeitet:

Sonecc

Gesperrter Benutzer
die Java Tags (oder wenigstens Code Tags) tragen (gepart mit Einrückungen und so) schon sehr zur lesbarkeit eines Codes bei. Also das nächste mal berücksichtigen...

Deinem Code fehlen schon einige Klammern, desweiteren benutzt du falsche Klassenbezeichner (System, nicht system)

Außerdem ist der "gegebene" Code ebenfalls nicht kompilierbar, da eine innere Klasse nicht den gleichen Namen haben kann, wie die umschließende Klasse.
Selbst wenn der Name in Ordnung wäre, würden dir die Berechtigungen fehlen um auf die Variablen zuzugreifen. (aufgrund der Tatsache dass dort alles private deklariert ist)
 

Landei

Top Contributor
Dumme Frage: Warum arg und value? Warum 4 (in Worten: vier) Referenzen auf List in einer einfach (?) verketteten Liste? Und was ist MappingEl? Kann es sein, dass dein Prof auch ein bisschen verwirrt ist?
 

lama

Mitglied
Hallo Blitzkrieg,

ein allgemeiner Hinweis.

ich definiere eine Zahl int k. und definiere ein Verweis curr (steht für current)

Warum benutzt du Abkürzungen bei den Variablennamen? Nenn curr doch ruhig gleich `current` und k `zahl` oder `number`. Die paar Zeichen mehr bringen einen nicht um und der Code ist viel einfacher zu lesen

Beste Grüße
 
T

Tomate_Salat

Gast
naja...aber kompilierbaren code sollte er euch trotzdem als Grundlage geben, oder habt ihr die Aufgabe, die Fehler noch rauszubauen, oder liegt hier einfach nur ein übertragungsfehler vor?
 

BlitzKrieg42

Mitglied
Dumme Frage: Warum arg und value? Und was ist MappingEl?
wie gesagt ich habe den Anfang kopiert und die Klasse umbenennt. muss noch MappungE1 ändern. value wird in einer anderen Methode benutzt.

das Löschen haben wir immer mit 2 Verweisen gemacht current und previous. Übrigens: ich studiere an der TU Berlin .
Das code werde ich editieren. Bitte sagt mal , ob es falsch ist .
LG
Alex
 
T

Tomate_Salat

Gast
Die vorgabe deines Profs ist einfach nicht kompilierbar und somit auch nicht ausführbar, darauf kannst du nicht aufbauen.

Also entweder ihr sollt die Vorgabe verbessern, heist die Fehler rausmachen (Sonecc hat sie ja aufgezählt) oder du hast es falsch abgeschrieben oder dein Prof ist ein idiot :D
 

XHelp

Top Contributor
Ok damit ich das richtig verstehe. Was ich gemacht habe ist für eine doppelt verkettete Liste wahr?

Naja, dein Code ist nicht vollständig, deswegen weiß ich nicht was du gemacht hast ;)
Aber in einer einfach verketteten Liste kannst du dich nur in eine Richtung bewegen. Bei einer doppelt verketteten eben in beide. Deswegen brauchst du bei der 1. nur den Vorgänger oder Nachfolger. Bei der doppelten beide.
 

XHelp

Top Contributor
Der Code hat doch nur remove-Methode, da fehlen noch ein paar Sachen bis zur Liste. Z.B. um irgendwas zu löschen musst du ja vorher die Möglichkeit haben irgendwas hinzuzufügen...
 

BlitzKrieg42

Mitglied
ja ich weiß. Ich wollte wissen wie man die Stelle des zu löschenden Elements findet. Löschen und einfügen kann ich selber machen. Ich bedanke mich für eure Hilfe. Ich würde gerne diesen Thread offen lassen ; falls ich noch weitere Fragen habe dann kann ich die hier posten.
Vielen Dank.
Alex
 

Sonecc

Gesperrter Benutzer
Sorry, aber wenn du sagst dass du den Code kopierst, dann tu es auch....
In der von der verlinkten Musterlösung ist der Code nämlich compilierbar und auch (auf den ersten blick) deutlich sinnvoller als das was du hier als gegeben dargestellt hattest...
 

BlitzKrieg42

Mitglied
Ich bin sehr froh , dass ich mich für dieses Forum entschieden habe. Offensichtlisch sind viele Mitglieder aktiv hier.
@Sonecc: sorry mein Fehler . Ich wollte den Namen der Klasse ändern . Nächstes mal kopiere ich den Code einfach wie der ist.
Neue Frage:
Was ist ein Iterator?Wozu wird ein Interface gebraucht?
LG
Alex
 
B

bygones

Gast
ich glaub du verwechselst hier n bisschen was.

das forum dient dazu anderen bei ihren Problemen mit Programmierung zu helfen, nicht code zu produzieren, den andere dann einfach übernehmen koennen
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
M Java Listen Java Basics - Anfänger-Themen 4
G Java Listen und Iterator Java Basics - Anfänger-Themen 2
R SQL ähnlicher Filter für Java Listen Java Basics - Anfänger-Themen 2
walker23m C++ Listen iteratoren in Java umwandeln Java Basics - Anfänger-Themen 3
X ADS Listen in JAVA Java Basics - Anfänger-Themen 2
S Verkettete Listen in Java Java Basics - Anfänger-Themen 11
T Java-Datenstruktur: zuweisen von Strings auf Listen von Strings Java Basics - Anfänger-Themen 10
K Datentypen Arrays in Java - Adress-Arithmetik im Vergleich zu Listen Java Basics - Anfänger-Themen 4
A rekursive Listen in Java? Java Basics - Anfänger-Themen 5
T Klasse in Java für doppelt verkettete Listen Java Basics - Anfänger-Themen 4
K Listen in Java Java Basics - Anfänger-Themen 3
H .java Dateien in Eclipse einbinden und ausführen Java Basics - Anfänger-Themen 1
onlyxlia Schlüsselworte Was meint man mit "einen Typ" in Java erstellen? Java Basics - Anfänger-Themen 2
O Java Kara geschweifte Klammern Java Basics - Anfänger-Themen 2
richis-fragen Mausrad logitech kann links und rechts klick wie in java abragen. Java Basics - Anfänger-Themen 15
XWing Java Klssenproblem Java Basics - Anfänger-Themen 4
R Umgebungsvariable java -cp gibt immer Java-Hilfe... Java Basics - Anfänger-Themen 3
farbenlos Csv Datei in Java einlesen Java Basics - Anfänger-Themen 18
F TableModelListener: java.lang.ArrayIndexOutOfBoundsException: 132 Java Basics - Anfänger-Themen 3
G Java 8 - Support-Ende Java Basics - Anfänger-Themen 7
T Java Weihnachtsbaum + Rahmen Java Basics - Anfänger-Themen 1
N Will mit Java anfangen Java Basics - Anfänger-Themen 13
Ü Java Array - Buchstaben als Zahlen ausgeben Java Basics - Anfänger-Themen 22
M Java Iterator Verständnisfrage Java Basics - Anfänger-Themen 6
M Java Mail Programm Java Basics - Anfänger-Themen 4
Sniper1000 Java 391 für Windows Java Basics - Anfänger-Themen 37
J Java long- in int-Variable umwandeln Java Basics - Anfänger-Themen 6
JaZuDemNo Java im Studium Java Basics - Anfänger-Themen 7
E Java Programm zur anzeige, ob Winter- oder Sommerzeit herrscht Java Basics - Anfänger-Themen 62
I QR code in Java selber generieren Java Basics - Anfänger-Themen 5
V Java-Ausnahmebehandlung: Behandlung geprüfter Ausnahmen Java Basics - Anfänger-Themen 1
krgewb Java Streams Java Basics - Anfänger-Themen 10
A Überwältigt von der komplexen Java Welt Java Basics - Anfänger-Themen 29
O Mehrfachvererbung auf Spezifikations- und Implementierungsebene in Java. Interfaces Java Basics - Anfänger-Themen 19
John_Sace Homogene Realisierung von Generics in Java ? Java Basics - Anfänger-Themen 19
P Meldung aus Java-Klasse in Thread an aufrufende Klasse Java Basics - Anfänger-Themen 1
R mit Java API arbeiten Java Basics - Anfänger-Themen 9
P JDK installieren Probleme bei der Java-Installation Java Basics - Anfänger-Themen 8
S Java: Wie sortiere ich eine ArrayList benutzerdefinierter Objekte nach einem bestimmten Attribut? Java Basics - Anfänger-Themen 2
Timo12345 JNLP File mit Java öffnen Java Basics - Anfänger-Themen 2
S Video Editierung mit Java.._ Java Basics - Anfänger-Themen 2
F Einstelungen in Java - CursorBlinkRate Java Basics - Anfänger-Themen 10
A PHP $_POST["name"] in Java Java Basics - Anfänger-Themen 3
vivansai21 Is there a oneliner to create a SortedSet filled with one or multiple elements in Java? Java Basics - Anfänger-Themen 9
Athro-Hiro Weißes Bild in Java erstellen Java Basics - Anfänger-Themen 3
Arjunreddy Can someone please tell me how to use a debugger in BlueJ(a Java environment) Java Basics - Anfänger-Themen 1
M Java assoziationen (UML) Java Basics - Anfänger-Themen 8
H Excel-Tabellen mit Java erstellen Java Basics - Anfänger-Themen 4
Simon16 Java ArrayListe von einer Klasse sortieren Java Basics - Anfänger-Themen 2
P Wie kann ich in meinem Java Programm etwas dauerhaft speichern? Java Basics - Anfänger-Themen 5
H Nutzt Eclipse alle CPU-Threads beim Ausführen von Java-Programmen? Java Basics - Anfänger-Themen 4
xXGrowGuruXx Java einstieg, leichte sache 0 verstanden Java Basics - Anfänger-Themen 7
A java.sql.SQLException: Data type mismatch. Java Basics - Anfänger-Themen 1
H Java-Programm zur Ausgabe von Zuständen Java Basics - Anfänger-Themen 80
N Java Spiel Figur auf dem Hintergrundbild bewegen. Java Basics - Anfänger-Themen 11
G Kann Java-Programm nicht als jar aufrufen, auch als EXE nicht Java Basics - Anfänger-Themen 19
N Java Taschenrechner hat Jemand vlt einen Tipp dafür wie ich jetzt die buttons verbinden kann und das Ergebnis auf dem textfield anzeigen lassen kann Java Basics - Anfänger-Themen 13
A Lerngruppe Java Java Basics - Anfänger-Themen 2
G Help me in the Java Program Java Basics - Anfänger-Themen 2
L Java- Vererbung Java Basics - Anfänger-Themen 4
LimDul Suche Java Stream Tutorial Java Basics - Anfänger-Themen 2
_so_far_away_ Ich möchte Java lernen Java Basics - Anfänger-Themen 11
benny1993 Java Programm erstellen für ein Fußball-Turnier Java Basics - Anfänger-Themen 3
M Datentypen While-Schleife eine Java Methode erstellen Java Basics - Anfänger-Themen 3
V Bild per Java Script austauschen Java Basics - Anfänger-Themen 7
MoxMorris this Keyword in Java Java Basics - Anfänger-Themen 14
D Wie kann man in Java nach Arrays auf Duplikate prüfen Java Basics - Anfänger-Themen 12
wolei JAVA Zeitdifferenz feststellen. Java Basics - Anfänger-Themen 4
DiyarcanZeren Rekursion in Java Java Basics - Anfänger-Themen 5
wolei Java generic interface in a generic class Java Basics - Anfänger-Themen 6
monsterherz Ablauf der Erstellung eines Java Programmes Java Basics - Anfänger-Themen 17
monsterherz Circle.java:5: error: <identifier> expected Java Basics - Anfänger-Themen 2
julian-fr Wie kann ich am besten Java lernen? Java Basics - Anfänger-Themen 17
A Java-Properties und -RessourceBundles Java Basics - Anfänger-Themen 5
lrnz22 Java-Basics-Aufgabe Java Basics - Anfänger-Themen 8
R Java kann nicht installiert werden Java Basics - Anfänger-Themen 8
marcelnedza Finde meinen Fehler in einer Methode nicht, Java Karol Java Basics - Anfänger-Themen 15
G In ein java Dokument Ton einbinden Java Basics - Anfänger-Themen 1
C was heisst es wenn java ']' erwartet ? Java Basics - Anfänger-Themen 2
KeinJavaFreak Erste Schritte Programm "Java(TM) Platform SE binary " nicht vorhanden Java Basics - Anfänger-Themen 1
KeinJavaFreak Erste Schritte Java "Executable Jar File" nicht vorhanden Java Basics - Anfänger-Themen 1
melisax Java 2D-Array Tabelle Java Basics - Anfänger-Themen 4
melisax Java Array Wert an bestimmtem Index angeben Java Basics - Anfänger-Themen 14
J Java Testklasse Java Basics - Anfänger-Themen 5
P Java Selenium . Parameterized.Parameters erzeugt eine Fehlermeldung Java Basics - Anfänger-Themen 14
W Java-Code mit Array Java Basics - Anfänger-Themen 14
W Java-Code Java Basics - Anfänger-Themen 2
P BeforeEach AfterEach werden nicht ausgeführt. Java / Selenium Java Basics - Anfänger-Themen 4
A Wie führe ich eine Batch-Datei von meiner Java-Anwendung aus? Java Basics - Anfänger-Themen 18
W Java code- TicTac toe Java Basics - Anfänger-Themen 51
Ostkreuz Java Docs Java Basics - Anfänger-Themen 9
R Java boolean Unterschied " == " und " = " Java Basics - Anfänger-Themen 3
D Java Programm mit Batch-Datei starten Java Basics - Anfänger-Themen 32
W Java-code Java Basics - Anfänger-Themen 8
W Java-code Java Basics - Anfänger-Themen 9
W Java-Code erklären Java Basics - Anfänger-Themen 6
A Java Kurs / Tutorial Java Basics - Anfänger-Themen 6
K Java Lotto Spiel; ich komme nicht weiter Java Basics - Anfänger-Themen 15
R Operatoren Rechenoperation in Java verwenden für Calculator Java Basics - Anfänger-Themen 2
P Java 2n Potenzieren Java Basics - Anfänger-Themen 1

Ähnliche Java Themen

Neue Themen


Oben