Listen

Sandro95

Bekanntes Mitglied
Hey Leute,
mal ne frage zu Listen , wie erkenne ich ob ich in der while( a!=Null) schauen muss oder while (a.nächster!=Null)?
Das ist mir noch etwas unschlüssig. Schaut mal im anhang dort sind 3 Methoden , 2 davon habe ich mit a!=null und eine mit a.nächster
 

Anhänge

  • WhatsApp Image 2020-08-14 at 00.52.45.jpeg
    WhatsApp Image 2020-08-14 at 00.52.45.jpeg
    89,8 KB · Aufrufe: 18
  • WhatsApp Image 2020-08-14 at 00.52.33.jpeg
    WhatsApp Image 2020-08-14 at 00.52.33.jpeg
    86,1 KB · Aufrufe: 17

Sandro95

Bekanntes Mitglied
Java:
public class Link {
  
    public int wert ;
    public Link nächster;
  
    public Link(int wert , Link nächster) {
        this.wert=wert;
        this.nächster=nächster;
    }

}



public class Liste {

    public Link anfang;
    public Link ende;

    public Liste(Link anfang) {
        this.anfang = anfang;
        this.ende = anfang;
    }

    public void add(Link neu) {

        if (this.anfang == null) {
            this.anfang = neu;
            this.ende=neu;
        } else {
            this.ende.nächster = neu;
            ende = ende.nächster;
        }

    }

    public void iter() {
        Link a = anfang;

        while (a != null) {

            System.out.print(a.wert + " ");

            a = a.nächster;
        }

    }

    public void anzEl() {
        Link a = anfang;
        int count = 0;

        while (a != null) {

            ++count;
            a = a.nächster;
        }
        System.out.println("Die liste besitzt " + count + " an Elementen");
    }

    public void fügeWertein(int value) {
        Link neu = new Link(value, null);
        Link a = anfang;

        while (a.nächster != null) {

            if (a.wert == value) {
                System.out.println("Wert ist schon vorhanden");
                return;

            }
            a = a.nächster;

        }
        a.nächster = neu;

    }


Das ist dann der Code in Code Tags :) Was meien spezifische Frage ist , steht ja Anfangs
 
Zuletzt bearbeitet von einem Moderator:
K

kneitzel

Gast
Also ein grober Unterschied ist:
Mit a != null läufst du komplett durch und am Ende ist a halt null.
Ist ok, wenn du alle Elemente einmal anpacken willst.

Mit a.next != null läufst du nur bis zum letzten Element. A ist dann nicht null sondern das letzte Element.

Also bei letzter Variante bleibst du beim Vorgänger stehen. In einer einfach verketteten Liste ist dies notwendig, wenn man den Vorgänger auch benötigt um z.B. da den next Wert anzupassen.
 

Sandro95

Bekanntes Mitglied
Also ein grober Unterschied ist:
Mit a != null läufst du komplett durch und am Ende ist a halt null.
Ist ok, wenn du alle Elemente einmal anpacken willst.

Mit a.next != null läufst du nur bis zum letzten Element. A ist dann nicht null sondern das letzte Element.

Also bei letzter Variante bleibst du beim Vorgänger stehen. In einer einfach verketteten Liste ist dies notwendig, wenn man den Vorgänger auch benötigt um z.B. da den next Wert anzupassen.


also , wenn ich durchlaufe beim durchlaufen zB die Elemente zählen möchte , a.wert ausgeben oder einfach nur ein Wertevergleich machen möchte dann laufe ich einmal komplett durch die liste durch mit a!= null?
Bei welche Operationen läuft man in der while zb(a.nächster!=null)?
 
K

kneitzel

Gast
Ja genau. Einfügen gehst du z.B. so lange durch, bis a.next == null ist oder a.next.wert so ist, dass der neue Wert davor kommen soll.

Aber vorsichtshalber noch die Bemerkung: Das ist natürlich nur eine Lösung. Man kann z.B. auch mit a != null und so prüfen und sich den Vorgänger merken. Also mit zusätzlicher Variable und so. Es gibt also oft mehrere Lösungsideen. Aber diese Alternative Lösung hat z.B. mehr code. Was einem besser gefällt muss jeder für sich entscheiden.
 
K

kneitzel

Gast
Ja, da hast du Recht. Wenn du bereits die notwendigen Elemente zur Hand hast, dann brauchst du das nicht.

Anfang ist immer klar, denn du hast ja den Zeiger auf das erste Element.

Das letzte Element hält man nicht zwingend vor. Das zu speichern ist somit eine Optimierung. Wenn du das letzte Element schon hast, musst du nicht mehr durch die Liste durch gehen.
 

temi

Top Contributor
In "nächster" steckt ja das Element, welches auf das aktuelle Element folgt. Einmal schaust du also, ob das aktuelle Element null ist, dann bist du am Ende angekommen. Im anderen Fall, schaust du, ob es nach dem aktuellen Element noch ein weiteres gibt (a.next != null).
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
D Listen in Listen in Listen ... ??? Java Basics - Anfänger-Themen 2
XWing listen Java Basics - Anfänger-Themen 7
FunkyPhil94 addLast und addFirst bei Listen Java Basics - Anfänger-Themen 6
S Einfach-Verkettete-Listen Ausgabe zeigt nur 1. und letzte instanz Java Basics - Anfänger-Themen 2
J 2 listen vergleichen, die auch null Elemente haben können ! Java Basics - Anfänger-Themen 9
W Liste mit Listen in JTable darstellen Java Basics - Anfänger-Themen 1
Buroto Threads Verschiedene .txt Dateien Auf Listen und Verbinden Java Basics - Anfänger-Themen 3
M Generics Vererbung Listen Java Basics - Anfänger-Themen 2
T Collections Sind Subklassen-Objekte in Listen mit Generics erlaubt? Java Basics - Anfänger-Themen 16
S Lineare listen verkettung Java Basics - Anfänger-Themen 7
S Listen , Nodes am ende anängen Java Basics - Anfänger-Themen 6
P Sortieren von Listen nach Attributen Java Basics - Anfänger-Themen 3
M Java Listen Java Basics - Anfänger-Themen 4
V einfach verkettete Listen Java Basics - Anfänger-Themen 10
A PhoneBook mit verketteten listen Java Basics - Anfänger-Themen 48
F ich brauche Hilfe bei Listen Java Basics - Anfänger-Themen 13
M (Sehr großes Problem) Listen als static in anderen Klassen verwendet Java Basics - Anfänger-Themen 12
G Java Listen und Iterator Java Basics - Anfänger-Themen 2
S Erklaerung Listen Java Basics - Anfänger-Themen 27
J Implementierung Listen-ADT Java Basics - Anfänger-Themen 131
I Alle Elemente von zwei Listen vergleichen Java Basics - Anfänger-Themen 1
L Skip Listen Java Basics - Anfänger-Themen 5
S Collections funktionale Listen (ListNode<E>) review und problem beim clone Java Basics - Anfänger-Themen 0
L Wie testet man (selbstgeschriebene) Listen sinnvoll? Java Basics - Anfänger-Themen 2
F Problem mit Listen Java Basics - Anfänger-Themen 5
J Listen Operationen Java Basics - Anfänger-Themen 4
O Unterschied Arrays, Listen, Mengen Java Basics - Anfänger-Themen 24
J Eine Liste von Listen erstellen Java Basics - Anfänger-Themen 11
A Sortierte Listen Java Basics - Anfänger-Themen 4
L Datenstrukturen/ Listen Java Basics - Anfänger-Themen 17
A Was könnten typische Prüfungsaufgaben zum Thema lineare, verkettete Listen sein? Java Basics - Anfänger-Themen 5
L Listen und Felder Java Basics - Anfänger-Themen 2
M Fragen zum Anlegen und Benutzen von Listen Java Basics - Anfänger-Themen 9
R Arrays und Listen Java Basics - Anfänger-Themen 1
R Listen richtig implementieren Java Basics - Anfänger-Themen 3
F Multidimensionale Listen Java Basics - Anfänger-Themen 3
F Wie String in unterschiedliche Listen teilen Java Basics - Anfänger-Themen 7
R Interface Eigene Objekte in Listen sortieren mit Interface Comparable Java Basics - Anfänger-Themen 5
T Objekte in Listen vererben Java Basics - Anfänger-Themen 3
A Klassen Klassen und Listen... Java Basics - Anfänger-Themen 5
Hacer Operationen einfach verketteter Listen Java Basics - Anfänger-Themen 22
S Methoden Vergleichen von zwei Listen in der Geschwindigkeit von O(n+m) Java Basics - Anfänger-Themen 32
P Listen sortieren mit Binärbaum gibt keine Ausgabe ab 10000 Integern Java Basics - Anfänger-Themen 14
C Listen Java Basics - Anfänger-Themen 3
C Zwei Listen verbinden Java Basics - Anfänger-Themen 1
C Zahlen merken mit Hilfe von Arrays/Listen Java Basics - Anfänger-Themen 2
E Feld von verketteten Listen Java Basics - Anfänger-Themen 11
T Überprüfung einer Aufgabe zu verketteten Listen Java Basics - Anfänger-Themen 5
S Liste mit Objekten und Listen Java Basics - Anfänger-Themen 9
JarJarBigs Frage zu Listen Java Basics - Anfänger-Themen 2
N verkettete Listen Java Basics - Anfänger-Themen 4
O Listen sort-Methode Java Basics - Anfänger-Themen 1
I Listen sortieren bei mehreren Listen zu einer Java Basics - Anfänger-Themen 2
L Lineare Listen Java Basics - Anfänger-Themen 2
S Listen Objekte nach LocalDateTime sortieren Java Basics - Anfänger-Themen 2
D Methoden Listen generieren Java Basics - Anfänger-Themen 4
A Sichtbarkeit in Methoden/Listen Java Basics - Anfänger-Themen 3
M verkettete Listen Java Basics - Anfänger-Themen 1
D Klausur Vorbereitung: Listen, Rekursion, Bäume & Vererbung Java Basics - Anfänger-Themen 3
S Vergleich von Listen Java Basics - Anfänger-Themen 6
I Zwei Listen vergleichen Java Basics - Anfänger-Themen 2
M Listen erstellen mit unterschiedlichen Reihenfolgen Java Basics - Anfänger-Themen 3
I Zwei Listen vergleichen bei n:m Beziehung Java Basics - Anfänger-Themen 2
I Zwei Listen: Wenn nicht vorhanden löschen Java Basics - Anfänger-Themen 4
I Prüfen von zwei Listen Java Basics - Anfänger-Themen 1
K Interface Generics, Interfaces und Listen - ich bin verwirrt. Java Basics - Anfänger-Themen 7
L Best Practice Alle Kombinationen aus Listenelementen, Anzahl Listen unterschiedlich Java Basics - Anfänger-Themen 6
llabusch Verkette Listen - Einfach und Doppelt Java Basics - Anfänger-Themen 3
S Unsortierte Listen - Frage zur "Verkettung" Java Basics - Anfänger-Themen 1
I Zwei Listen vergleichen Java Basics - Anfänger-Themen 7
I Listen, for - Schleifen Java Basics - Anfänger-Themen 8
P Listen Size stimmt nicht Java Basics - Anfänger-Themen 5
O Objekt Listen serialisierung und deserialisieren Java Basics - Anfänger-Themen 5
L Collections Objekte in Listen speichern Java Basics - Anfänger-Themen 3
G 2 Listen kombinieren und nach abc sortieren Java Basics - Anfänger-Themen 9
D Annonyme Innere Klasse: Listen mit geradem Index ausgeben Java Basics - Anfänger-Themen 6
G Listen sortieren Java Basics - Anfänger-Themen 3
G Generic und Listen Java Basics - Anfänger-Themen 8
R SQL ähnlicher Filter für Java Listen Java Basics - Anfänger-Themen 2
Y Collections 4 Listen Java Basics - Anfänger-Themen 14
S OOP/ Listen...etc... Java Basics - Anfänger-Themen 14
E Listen Java Basics - Anfänger-Themen 2
V Methoden Verkettete Listen Index eines Elementes ausgeben Java Basics - Anfänger-Themen 10
B Listen Java Basics - Anfänger-Themen 3
B eigene klasse in listen eintragen Java Basics - Anfänger-Themen 6
B Map per Listen Java Basics - Anfänger-Themen 2
S Erfahrungswerte von schnelles durchlaufen von Listen mit 2 Werten Java Basics - Anfänger-Themen 10
Joew0815 Problem mit Listen: add() Java Basics - Anfänger-Themen 11
P Zeichenorientierte & Serialisierte Datenverarbeitung Listen Java Basics - Anfänger-Themen 8
E Listen und Generics Java Basics - Anfänger-Themen 9
L dynamisches erzeugen von array Listen Java Basics - Anfänger-Themen 7
E Listen und Duplikate Java Basics - Anfänger-Themen 2
R Hilfe bei Listen Java Basics - Anfänger-Themen 10
F Collections Liste von Listen Java Basics - Anfänger-Themen 21
A Methoden Anfängerfrage: 2 Listen Vergleichen Java Basics - Anfänger-Themen 7
walker23m C++ Listen iteratoren in Java umwandeln Java Basics - Anfänger-Themen 3
X Listen und verschiedene Methoden Java Basics - Anfänger-Themen 6
N Listen Java Basics - Anfänger-Themen 5
S Listen Klasse selbst schreiben Java Basics - Anfänger-Themen 6
propra Objekte in mehreren Listen Java Basics - Anfänger-Themen 6

Ähnliche Java Themen

Neue Themen


Oben