kurze frage zu meinem Code ...

Mino1337

Mitglied
Hallo,

dieser Code macht eine Doppelt verkettete Liste und funktioniert NUR in einer zeile komme ich nicht klar =) ...

Java:
public class DoppeltVerketteteListe<T> {
private class ListElem {
T data;
ListElem next;
ListElem prev;
public ListElem(T data) {
this.data = data;
}
}
private ListElem head;
private ListElem tail;
public Liste() {
head = null;
tail = null;
}
public void add(T data, int i) {
ListElem newElem = new ListElem(data);
//leere Liste, kann nach Aufgabenstellung auch weggelassen werden
if(head == null) {
head = newElem;
tail = newElem;
}
//Liste hat mind. 1 Element
else {
ListElem current = head;
int currentIdx = 0;
while(current.next != null && currentIdx < i) {
current = current.next;
currentIdx++;
}
//i <= Listenlaenge
if(currentIdx >= i) {
newElem.next = current;
newElem.prev = current.prev;
newElem.next.prev = newElem;
if(current == head)
head = newElem;
else
newElem.prev.next = newElem;
}
//i > Listenlaenge
else {
newElem.prev = current;
newElem.prev.next = newElem;
tail = newElem;
}
}
}
}

In Z25 da steht
Java:
ListElem current = head;
, das geht irgendwie nicht weil das Objekt current nicht erzeugt wurde mit dem "new" ...

Es soll ja einen zeiger darstellen aber ich verstehe auch nicht so recht woher dieses Mysteriöse current jetzt weiss wer sein vorgänger und wer sein nachfolger ist aber das habe ich mal einfach so als fakt hingenommen ...

Also wenn current kein Objekt ist was ists dann ?!
 

Joose

Top Contributor
In Z25 da steht
Java:
ListElem current = head;
, das geht irgendwie nicht weil das Objekt current nicht erzeugt wurde mit dem "new" ...

Ja ist auch nicht notwendig! Du weißt "current" den Wert von dem Attribut "head" zu.
Sprich nach dieser Zeile zeigen "current" und "head auf dasgleiche Element :)

Am besten du führst den Code einfach testweise aus und debuggst ihn! Dann wird dir wahrscheinlich vieles klarer.
 
Zuletzt bearbeitet:

ceving

Aktives Mitglied

... ist ohne Einrückung unlesbar!

Java:
public class DoppeltVerketteteListe<T> {
  private class ListElem {
    T data;
    ListElem next;
    ListElem prev;
    public ListElem(T data) {
      this.data = data;
    }
  }
  private ListElem head;
  private ListElem tail;
  public Liste() {
    head = null;
    tail = null;
  }
  public void add(T data, int i) {
    ListElem newElem = new ListElem(data);
    //leere Liste, kann nach Aufgabenstellung auch weggelassen werden
    if(head == null) {
      head = newElem;
      tail = newElem;
    }
    //Liste hat mind. 1 Element
    else {
      ListElem current = head;
      int currentIdx = 0;
      while(current.next != null && currentIdx < i) {
        current = current.next;
        currentIdx++;
      }
      //i <= Listenlaenge
      if(currentIdx >= i) {
        newElem.next = current;
        newElem.prev = current.prev;
        newElem.next.prev = newElem;
        if(current == head)
          head = newElem;
        else
          newElem.prev.next = newElem;
      }
      //i > Listenlaenge
      else {
        newElem.prev = current;
        newElem.prev.next = newElem;
        tail = newElem;
      }
    }
  }
}
 

ceving

Aktives Mitglied
Es soll ja einen zeiger darstellen aber ich verstehe auch nicht so recht woher dieses Mysteriöse current jetzt weiss wer sein vorgänger und wer sein nachfolger ist aber das habe ich mal einfach so als fakt hingenommen ...

Braucht man nicht hinnehmen. Das ergibt sich direkt aus dem Code. "current" ist definiert als eine Variable vom Typ "ListElem". Und die Definition von "ListElem" am Anfang der Klasse zeigt, dass alle "ListElem"s ein "next" und "prev" haben. Somit hat auch "current" einen Vorgänge und Nachfolger.

Also wenn current kein Objekt ist was ists dann ?!

"current" ist selbstverständlich ein Objekt. Aber alle Objekt in Java sind als Referenz implementiert. Das ist mit Zeiger gemeint. Wenn du den Wert von "head" an die Variable "current" zuweist, wird nicht das ganze Objekt im Speicher kopiert sondern es wird nur die Adresse, die angibt, wo das Objekt im Hauptspeicher wohnt, kopiert. Die Anfertigung einer vollständigen Kopie eines Objekts nennt sich in Java "clonen". Es gibt nur wenig Objekte, für die das geht. Und die, für die das geht, implementieren das Interface Cloneable.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
F Kurze Frage zu replace() Java Basics - Anfänger-Themen 19
dieter000 Kurze Frage kann mir ejmand kurz diesen Code erklären, bzw wie man die zeilen erklärt und so Java Basics - Anfänger-Themen 1
JD_1998 Array-Position aus einer Methode in einer anderen ausgeben (Kurze Frage) Java Basics - Anfänger-Themen 2
M Rationale Zahl erkennen - Kurze Frage zum Restwert nach Division Java Basics - Anfänger-Themen 3
L Kurze Frage... Java Basics - Anfänger-Themen 2
C Kurze Frage zur Polymorphie Java Basics - Anfänger-Themen 1
B Rekursion Schneeflocke - Kurze Frage zur Methode Java Basics - Anfänger-Themen 11
TechGirl LinkedList - kurze allgemeine Frage Java Basics - Anfänger-Themen 17
T Objektorientierung-Kurze Frage Java Basics - Anfänger-Themen 5
L Kurze Frage zu verschachtelten Schleifen Java Basics - Anfänger-Themen 3
D Compiler-Fehler kurze Frage (Fehler): runde Klammern im Println Java Basics - Anfänger-Themen 3
M Baum Code kurze frage ... Java Basics - Anfänger-Themen 6
T Kurze Frage zu Arrays Java Basics - Anfänger-Themen 4
S Java - Client/Server mit Stomp kurze Frage Java Basics - Anfänger-Themen 0
T Eine kurze frage vor der prüfung bitte. Java Basics - Anfänger-Themen 5
X Kurze Frage zu Java Doc Java Basics - Anfänger-Themen 3
G Kurze Frage zu Arrays Java Basics - Anfänger-Themen 3
G Warteschlange/Reihungen kurze syntaktische Frage Java Basics - Anfänger-Themen 2
J Erste Schritte Kurze Frage zu Listenern und If-Bedingung Java Basics - Anfänger-Themen 2
S Erste Schritte HashMap Kurze Frage - Werte über Schleife ausgeben Java Basics - Anfänger-Themen 30
M kurze frage: Ohne index.of position von string angeben Java Basics - Anfänger-Themen 16
A Methoden Langer Text, kurze Frage Java Basics - Anfänger-Themen 10
S Kurze Frage zur Effizienz: Java Basics - Anfänger-Themen 4
R Kurze Ouelltext frage Java Basics - Anfänger-Themen 3
M kurze Frage zu Graphics Java Basics - Anfänger-Themen 5
Screen Kurze Frage Umwandlung von Zahlen Java Basics - Anfänger-Themen 2
J Math.random() - kurze frage. Java Basics - Anfänger-Themen 20
S Kurze Frage zum Ergebniss Java Basics - Anfänger-Themen 5
A kurze frage zu arrays und deren zuweisung Java Basics - Anfänger-Themen 11
J Kurze Frage zur Primzahlberechnung Java Basics - Anfänger-Themen 8
B kurze Frage if(!) Java Basics - Anfänger-Themen 19
K Kurze Frage zur Sortierung von Array-Inhalten Java Basics - Anfänger-Themen 5
G kurze frage zu if schleifen Java Basics - Anfänger-Themen 15
G kurze if frage Java Basics - Anfänger-Themen 8
G Kurze Frage zur Erstellung des Projektplans Java Basics - Anfänger-Themen 7
C OOP - Kurze Frage Java Basics - Anfänger-Themen 12
F Kurze Frage: JLabel in BorderLayout einfügen Java Basics - Anfänger-Themen 2
J QuickSort - kurze Frage Java Basics - Anfänger-Themen 9
A Kurze Frage zur Verwendung von this Java Basics - Anfänger-Themen 9
Vivien Kurze Verständnisfrage zu Java Point aus java.awt.* Java Basics - Anfänger-Themen 5
S Kurze Verständnissfrage Java Basics - Anfänger-Themen 4
N Kurze Hilfe !! Java Basics - Anfänger-Themen 3
A 2 kurze Anfänger fragen Java Basics - Anfänger-Themen 6
B Methoden Tricky, kurze Schreibweise? Java Basics - Anfänger-Themen 3
M Kurze Verständnisfrage zu einer Java Aufgabe Java Basics - Anfänger-Themen 12
V Ganz kurze Java-Hilfe - Ich finde meinen Fehler nicht Java Basics - Anfänger-Themen 4
R Kurze Linien alle x-Pixel Java Basics - Anfänger-Themen 2
U ArrayList kurze Einführung Java Basics - Anfänger-Themen 3
2 Datentypen Kurze Schreibform bei ArrayList (Vs String Array) Java Basics - Anfänger-Themen 6
P OOP 3 kurze Fragen Java Basics - Anfänger-Themen 2
J Benötige kurze Definition zum Programm Java Basics - Anfänger-Themen 2
R klausurvorbereitung uni HILFE!! kurze fragen,kurze antworten Java Basics - Anfänger-Themen 9
D 2 kurze Fragen Java Basics - Anfänger-Themen 5
Q 2 kurze Fragen Java Basics - Anfänger-Themen 3
D Kurze Fragen zu setVisible. Java Basics - Anfänger-Themen 4
M Kurze Pause ins Programm einbauen Java Basics - Anfänger-Themen 5
Zrebna Frage zu Test-Driven Development (TDD) Java Basics - Anfänger-Themen 3
I Frage Thymeleaf -> Fehler ignorieren und mit "" ersetzen? Java Basics - Anfänger-Themen 15
I Frage Thymeleaf -> Prefix / Suffix ändern? Java Basics - Anfänger-Themen 11
D Rekursions Probleme / frage Java Basics - Anfänger-Themen 4
T Frage zu Parse Java Basics - Anfänger-Themen 2
H Frage an die Profis Java Basics - Anfänger-Themen 4
J Eine konzeptionelle Frage zu OOP Java Basics - Anfänger-Themen 3
P Frage zu Rekursion und Backtracking Java Basics - Anfänger-Themen 2
H Frage zur Ausgabe Java Basics - Anfänger-Themen 4
H Frage zu arithmetischen Operationen Java Basics - Anfänger-Themen 20
JavaSchmecktLecker Polymorphie Frage zur Methodenüberschreibung Java Basics - Anfänger-Themen 21
J Frage zu einem "Taschenrechner" code Java Basics - Anfänger-Themen 9
B Erste Schritte Frage zu Instanzierung und Referenzen Java Basics - Anfänger-Themen 8
DoubleM Runtime.getRuntime().exec Frage Java Basics - Anfänger-Themen 2
J Eine theoretische Frage zur Praxis - JPanel oder Canvas Java Basics - Anfänger-Themen 5
O Frage: Formaler Typbezeichner? Java Basics - Anfänger-Themen 3
I BlueJ Queue Frage für Klausur Java Basics - Anfänger-Themen 2
N Verständnis Frage zu Variablen Java Basics - Anfänger-Themen 3
N Spezielle frage zum Comparator Java Basics - Anfänger-Themen 6
L Frage zum Array Java Basics - Anfänger-Themen 1
A Frage zum UML Design Java Basics - Anfänger-Themen 1
I Hilfe bei Klausur Frage Java Basics - Anfänger-Themen 8
izoards Drucken Frage zu FAQ Beitrag Java Basics - Anfänger-Themen 2
J Frage zu meinem Code (OOP) Java Basics - Anfänger-Themen 4
sserio Split() -> Regex Frage. Java Basics - Anfänger-Themen 7
A OCA Study Guide: 2. Frage aus Kapitel 3 Java Basics - Anfänger-Themen 9
sserio Date Library Frage Java Basics - Anfänger-Themen 9
Max246Sch Frage zu Währungsrechner Code Java Basics - Anfänger-Themen 2
sserio Frage zu HashMaps Java Basics - Anfänger-Themen 20
sserio Frage zu Threading - Multithreading Java Basics - Anfänger-Themen 2
sserio Frage zu Lambda Ausdrücken Java Basics - Anfänger-Themen 7
sserio Frage zu BigInteger Java Basics - Anfänger-Themen 1
D Frage bzgl. Enum-Handhabung Java Basics - Anfänger-Themen 16
xxx12 Frage Java Basics - Anfänger-Themen 2
I Generelle Frage zu Mikroservices (Spring Boot?), Docker... Java Basics - Anfänger-Themen 7
R Frage zu Methoden (Rückgabewert u. ohne.) Java Basics - Anfänger-Themen 2
A Frage zur programmierung Java Basics - Anfänger-Themen 12
M Frage zur Methode split der Klasse String Java Basics - Anfänger-Themen 32
R Input/Output Frage zu Java IO Java Basics - Anfänger-Themen 6
M Frage zu printWriter Java Basics - Anfänger-Themen 5
C Frage zu OLSMultipleLinearRegression Java Basics - Anfänger-Themen 31
KogoroMori21 Frage zum Euklidischen Algorithmus Java Basics - Anfänger-Themen 11
S Verständnis-Frage zu einer HÜ? Java Basics - Anfänger-Themen 1
F Frage betreff Programm mit dem man C++-Code in JAVA-Code übersetzen lassen kann Java Basics - Anfänger-Themen 2

Ähnliche Java Themen

Neue Themen


Oben