Methoden Entferne alle identische Knoten (Typ String) aus verkettete Liste

R

Rah2k

Mitglied
Hallo,
ich möchte gerne alle Knoten, die identisch mit einem übergebenen String sind, aus der Liste entfernen - inklusive Head-Knoten.
Ausschnitt aus meiner List-Klasse: Es geht um die deleteThis-Methode.
Code:
public class SinglyLinkedList {
   
    private Node start;
   
    public void add(String data) {
        Node element = new Node(data);
        if (start==null) {
            start = element;
        } else {
            Node temp = start;
            while(temp.next!=null) { //Bis zum letzten Element durchlaufen
                temp = temp.next;
            }
            temp.next =  element; //Das letzte Element = null, also hier einfügen
        }
    }

    public boolean isElementOf(String data) {
        Node temp = start;
        while (temp!=null) {
            if (temp.getStr().equals(data)) {
                return true;
            }
            temp = temp.getNext();
        }
        return false;
    }

    public int getListPosition(String data) {
        int count = 0;
        Node temp = start;
        while (temp!=null) {
            if (temp.getStr().equals(data)) {
                return count;
            }
            temp = temp.getNext();
            count++;
        }
        return count;
    }

    public void deleteThis(String data) {
        Node temp = start;
        if (isElementOf(data)) {
            Node previous = null;
            while (temp!=null) {
                if (getListPosition(data)==0) { //Wenn Head gelöscht werden soll
                    start = temp.next;
                    continue;
                }
               
                if (temp.getStr().equals(data)) {
                    previous.setNext(temp.getNext());
                }
                previous = temp;
                temp = temp.getNext();
            }
        } else {
            return;
        }
        return;
    }
}

main:
Code:
    public static void main(String[] args) {
       
        //test
        SinglyLinkedList liste2 = new SinglyLinkedList();
        liste2.add("TEST2");
        liste2.add("TEST2");
        liste2.add("TEST");
       
        liste2.deleteThis("TEST2");
        liste2.printListStr();
    }

Würde mich freuen wenn mit jemand weiterhelfen kann.
 
H

httpdigest

Top Contributor
Leute, benutzt mehr Rekursion! :)
Java:
public void deleteThis(String data) {
  start = delete(start, data);
}
private Node delete(Node node, String data) {
  if (node == null)
    return null;
  Node n = delete(node.getNext(), data);
  if (node.getStr().equals(data))
    node = n;
  else
    node.setNext(n);
  return node;
}
 
H

httpdigest

Top Contributor
Ich denke, grammatikalisch ist "Singly" auch richtig. Das singly ist ja das Adverb von single zu linked. "Wie ist es linked?" Singly. Das unterstützen auch diverse Online-Referenzen:
- https://en.wikipedia.org/wiki/Linked_list#Singly_linked_list
- https://en.wikibooks.org/wiki/Data_Structures/Singly_Linked_Lists

EDIT:
Ist in etwa vergleichbar mit "QuicklyWrittenArticle". Da würde man ja auch nicht "QuickWrittenArticle" (bzw. "QuickAndWrittenArticle") sagen, da der Artikel ja nicht schnell und geschrieben ist, sondern schnell geschrieben.
 
Zuletzt bearbeitet:
R

Rah2k

Mitglied
Leute, benutzt mehr Rekursion! :)
Java:
public void deleteThis(String data) {
  start = delete(start, data);
}
private Node delete(Node node, String data) {
  if (node == null)
    return null;
  Node n = delete(node.getNext(), data);
  if (node.getStr().equals(data))
    node = n;
  else
    node.setNext(n);
  return node;
}
Deine Lösung funktioniert wunderbar! So ganz verstehe ich allerdings den Ablauf nicht, habe nicht viel mit Rekursion bisher gemacht. Also:
- Aufruf delete()
- node ist != null
- Erneuter Aufruf delete(), mit nächsten Knoten
- Dann am Ende ist Null-Knoten erreicht
- Müsste dann nicht hier die Methode verlassen werden? (return null) Stattdessen wird die If-Anweisung ausgeführt. Das verstehe ich nicht ganz.

Danke vorab für kurze Erläuterung.
 
H

httpdigest

Top Contributor
Ein return beendet immer nur diese eine Methodenausführung und nicht alle. Wenn eine Methodenausführung mit return zurückkehrt, dann geht es ja mit der Ausführung des Aufrufers weiter. Also nach dem delete()-Aufruf.
Der Trick bei dieser rekursiven Methode ist, dass die Aufgabe einer einzelnen delete()-Ausführung nur ist, zu ermitteln, ob dieser Knoten (node Parameter) oder ein nächster Knoten zurückgegeben und damit als Folgeknoten für eine vorherigen Ausführung verwendet werden soll. Wenn wir induktiv annehmen, dass das, was ein delete()-Aufruf zu jedem Zeitpunkt berechnet und zurückgibt, genau der nächste Knoten wäre, der eben nicht equals zum übergebenen data ist und dass alle Folgeknoten daran schon korrekt gefiltert sind, dann ist die Aufgabe der aktuellen Ausführung nur noch, zu gucken, ob denn der Knoten für diese Ausführung (der node Parameter) gefiltert werden soll, oder nicht.
Ich hoffe, das war etwas verständlich.

Ansonsten ist eine saubere iterative (mit Schleifen) Lösung auch nicht schwer.
 
H

httpdigest

Top Contributor
Habe die rekursive Lösung mal zu einer iterativen Lösung umgewandelt.
Wenn du willst, kannst du hier ja noch ein bisschen "Fill in the gaps" spielen: :)
Java:
public void deleteThis(String data) {
  Node s = null, n = start;
  for (start = null; n != null; n = ____)
    if (!n.getStr().equals(data))
      s = deleteThis(____, ____);
}
private Node deleteThis(Node s, Node n) {
  if (s == null)
    start = ____;
  else
    s.setNext(____);
  return ____;
}
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
G Wie entferne ich einen "Abbrechen" Button? Java Basics - Anfänger-Themen 6
G Elemente aus jList entferne. Java Basics - Anfänger-Themen 2
E Wie gebe ich alle Daten zwischen zwei Zeitpunkten aus? Java Basics - Anfänger-Themen 2
crrnogorka Letzte Zeile einer Tabelle "überschreibt" alle anderen Zeilen Java Basics - Anfänger-Themen 1
C alle möglichen Kombinationen zweier Ziffern auf drei / vier / und 'n" Stellen Java Basics - Anfänger-Themen 11
H Alle Geraden zahlen bis 10 ausgeben Java Basics - Anfänger-Themen 11
L Alle Ziele in einem Raster abknallen Java Basics - Anfänger-Themen 17
J Alle Werte eines Strings zusammen addieren Java Basics - Anfänger-Themen 15
S Laufzeit Quicksort wenn alle Elemente gleich sind Java Basics - Anfänger-Themen 4
B Alle Links in einem Text suchen und ersetzen mit einem neuen Link Java Basics - Anfänger-Themen 18
K Array alle Werte aufsummieren und ausgeben Java Basics - Anfänger-Themen 6
Dimax Erste Schritte String replace alle Zeichen Java Basics - Anfänger-Themen 10
L Wie vergrößere ich ein Rechteck in alle Richtungen um eins und bekomme dessen Rand? Java Basics - Anfänger-Themen 2
L Breadth-First Search statt einem Pfad, alle Pfade herausfinden Java Basics - Anfänger-Themen 4
X Erste Schritte String: Alle doppelten Leerzeilen entfernen Java Basics - Anfänger-Themen 21
M Regex-Ausdruck: Alle Zeichen bis auf ein bestimmtes erlauben (p{L}) Java Basics - Anfänger-Themen 5
I Alle Elemente von zwei Listen vergleichen Java Basics - Anfänger-Themen 1
Kirby.exe Alle möglichen Error Möglichkeiten abfangen Java Basics - Anfänger-Themen 33
M Unterklasse soll nicht alle Methoden erben Java Basics - Anfänger-Themen 3
V Erste Schritte for-Schleife; Ausgabe soll alle 5 Sekunden erfolgen. Java Basics - Anfänger-Themen 4
A Alle true Werte eines boolean Arrays herausfiltern Java Basics - Anfänger-Themen 19
D Alle Möglichkeiten, n-Anzahl aus Elementen aus einem Array zu wählen, ausgeben? Java Basics - Anfänger-Themen 23
M prüfen ob alle array werte gleich sind Java Basics - Anfänger-Themen 27
F Alle Zeichenkombinationen eines Strings iterativ herausfinden Java Basics - Anfänger-Themen 26
L Classpath Alle Dateien im Classpath finden Java Basics - Anfänger-Themen 4
G Überprüfen ob alle Ziffern von 1-9 in einem Integer vorhanden sind Java Basics - Anfänger-Themen 6
J Erste Schritte Alle möglichen ausgaben von 5 Zahlen als Vector Java Basics - Anfänger-Themen 7
D Methoden Eigene Methode um alle Ausgaben aufzurufen Java Basics - Anfänger-Themen 17
F Ordner auf alle Unterdatein abfragen Java Basics - Anfänger-Themen 3
A In einem String alle Eigennamen zählen Java Basics - Anfänger-Themen 6
B Klassen Alle Unter-Objekte durchlaufen in der Hauptklasse Java Basics - Anfänger-Themen 10
W ArrayList löscht alle Elemente bis auf eines Java Basics - Anfänger-Themen 2
B Webservice -> alle parameter bekommen von form Java Basics - Anfänger-Themen 2
das_leon Alle Zeilen einer CSV-Datei auslesen Java Basics - Anfänger-Themen 1
C HashMap - alle keys haben values der letzten put-Anweisung Java Basics - Anfänger-Themen 3
F Eclipse alle Projekt weg Java Basics - Anfänger-Themen 6
V Alle Komponenten eines JPanels Java Basics - Anfänger-Themen 14
I gemeinsame Config-Datei für alle Windows-User Java Basics - Anfänger-Themen 5
H JButton - Wechsel der Textfarbe alle 500ms Java Basics - Anfänger-Themen 10
DaCrazyJavaExpert Alle Zahlenkombinationen aus 9 zahlen finden Java Basics - Anfänger-Themen 17
F Alle Objekte einer Klasse nach Eigenschaft durchsuchen Java Basics - Anfänger-Themen 8
M Alle Instanzen einer Klasse ansprechen Java Basics - Anfänger-Themen 4
S Problem: Array alle Einträge gleich Java Basics - Anfänger-Themen 10
Z Enter Taste alle 0,5 Sekunden ausführen Java Basics - Anfänger-Themen 1
U RegEx alle Kommas bei den Zahlen in Punkt umwandeln Java Basics - Anfänger-Themen 3
K alle Vorkommen einer bestimmten Ziffer in einer Zahl zählen Java Basics - Anfänger-Themen 2
X Minimax-Algorithmus über alle Kanten möglich? - Kanten darstellen Java Basics - Anfänger-Themen 1
C Alle Zweierpotenzen bis 2^10 ausgeben lassen Java Basics - Anfänger-Themen 15
B Alle Attribute von Klasse bekommen und ändern Java Basics - Anfänger-Themen 12
M Input/Output Alle Zeilen auslesen und in Variable speichern Java Basics - Anfänger-Themen 5
W Mozilla Thunderbird email an alle Kontakte Java Basics - Anfänger-Themen 3
F Methode alle 15min ausführen Java Basics - Anfänger-Themen 5
D Alle möglichen Kombinationen in einem Array ausgeben Java Basics - Anfänger-Themen 2
I Alle Laufwerke und deres Pfade ausgeben Java Basics - Anfänger-Themen 6
S Classpath: Alle .jars innerhalb eines Ordners einbinden Java Basics - Anfänger-Themen 4
G Alle Objekte und Variablen automatisch ausgeben Java Basics - Anfänger-Themen 7
I Programm, welches eine Textzeile einliest und alle darin enthaltenen Buchstaben umwandelt Java Basics - Anfänger-Themen 3
G Wie bekomme ich alle Ausgaben von runTime.exec() Java Basics - Anfänger-Themen 7
L Best Practice Alle Kombinationen aus Listenelementen, Anzahl Listen unterschiedlich Java Basics - Anfänger-Themen 6
M Compiler-Fehler Alle Methoden eines Interfaces Implementiert dennoch Fehler Java Basics - Anfänger-Themen 3
I Alle Zeitzonen in Liste speichern Java Basics - Anfänger-Themen 4
F alle 100ms Befehle ausführen Java Basics - Anfänger-Themen 26
M Alle Sublisten einer bestimmten Laenge berechnen Java Basics - Anfänger-Themen 2
F Alle DEMOS fast veraltet...? Java Basics - Anfänger-Themen 13
J Alle Leerzeichen aus String entfernen Java Basics - Anfänger-Themen 13
D Methoden Alle Siebenstelligen Primpalidrome von PI Java Basics - Anfänger-Themen 6
K Durch alle Attribute eines Objektes iterieren Java Basics - Anfänger-Themen 6
P Klassen Alle Strings einer ArrayList<eigeneKlasse> anspre Java Basics - Anfänger-Themen 2
W String von hinten alle drei Zeichen abschneiden und in umgekehrter Reihenfolge ausgeben. Java Basics - Anfänger-Themen 9
M Stürzen alle Rekursive Methoden irgendwann ab? Java Basics - Anfänger-Themen 11
M Alle möglichen Strings Java Basics - Anfänger-Themen 5
J Alle Wörter der Länge n mit 0 und 1 Java Basics - Anfänger-Themen 17
T Alle Threads .notify() Java Basics - Anfänger-Themen 13
G Methoden Alle Objekte der ArrayList ausgeben funktioniert nicht. Java Basics - Anfänger-Themen 12
N Klassen Class nur einmal ausführen und sie speichert daten für alle anderen classes? Java Basics - Anfänger-Themen 3
M Klassen Auf Alle Array Methoden gleichzeitig zugreifen Java Basics - Anfänger-Themen 8
D Frame schließt gleich alle Frames Java Basics - Anfänger-Themen 5
T Wie mache ich einen Timer der alle 2 sekunden aufgerufen wird? Java Basics - Anfänger-Themen 5
D JFileChooser "alle Dateien" unterbinden Java Basics - Anfänger-Themen 3
S Aus zwei Dateipfaden alle Dateien auslesen Java Basics - Anfänger-Themen 11
B Frage zur Effizienz - alle Array-Felder initialisieren oder jedes Feld auf null prüfen? Java Basics - Anfänger-Themen 4
F Geht in alle Case rein, warum?? Java Basics - Anfänger-Themen 12
R Alle Klassen ermitteln, die Interface implementieren / Reflection Java Basics - Anfänger-Themen 51
M Primzahlen - es werden alle Nicht-Primzahlen ausgegeben Java Basics - Anfänger-Themen 5
L RandomAccessFile liest nicht alle Zeichen Java Basics - Anfänger-Themen 3
S Warten bis alle Threads fertig sind Java Basics - Anfänger-Themen 12
M Class will alle Variablen als static haben Java Basics - Anfänger-Themen 11
E Erste Schritte Eclipse kompiliert alle Projekte im Workspace Java Basics - Anfänger-Themen 10
J Alle Vorkommen eines chars in einem Array durch einen anderen char ersetzen Java Basics - Anfänger-Themen 10
S Alle 60min prüfen ob eine Datei da ist Java Basics - Anfänger-Themen 6
Dit_ Funktion alle 24 Stunden ein mal aufrufen Java Basics - Anfänger-Themen 3
Dit_ Input/Output Alle Exceptions protokollieren Java Basics - Anfänger-Themen 9
S Regex - alle Matches ausgeben? Java Basics - Anfänger-Themen 2
2 Alle Werte die mit n Würfeln mit m Seiten geworfen werden können in ein n Dimensionales Array Java Basics - Anfänger-Themen 15
B Alle Benutzer anzeigen Java Basics - Anfänger-Themen 17
S Suchmaske alle Möglichkeiten effinzent durchgehen Java Basics - Anfänger-Themen 4
R Kurze Linien alle x-Pixel Java Basics - Anfänger-Themen 2
K Alle vorkommen eines Zeichens in StringBuffer Objekt löschen Java Basics - Anfänger-Themen 6
D X Werte in ArrayList von Point Objekte alle gleich ? Java Basics - Anfänger-Themen 11
H Alle Array-Elemente auf einmal überprüfen? Java Basics - Anfänger-Themen 10

Ähnliche Java Themen

Anzeige

Neue Themen


Oben