Verständnisfragen bezüglich Liste

M

Mr.Käse

Gast
Moin,

Wir haben in der Schule letztens die Datenstruktur einfach verkettete Liste programmiert und ich habe da noch einige Fragen, die mir mein Lehrer nicht so richtig beantworten konnte, dass ich es nachvollziehen konnte.

So haben wir für die Daten der Knoten ein Interface programmiert, an das wir die eigentliche Klasse mit den zu verwaltenden Daten angehängt haben. Meine Frage wäre jetzt, warum nimmt man ein Interface? Was hat das für Vorteile? Und warum verwendet man bei der eigentlichen Klasse, die die Daten verwaltet 'implements' und nicht 'extends', um vom Inteface "zu erben"? Ist das einfach so in Java festgelegt worden oder besteht die Möglichkeit beide Schlüsselwörter zu verwenden?

Meine nächste Frage bezieht sich auf den Fakt, der uns vorgegeben wurde, dass die Liste eine rekursive Datenstruktur ist. Meine Frage ist jetzt, was allgemein kennzeichnend für eine rekursive Datenstruktur ist bzw. was das bedeutet, wenn eine Datenstruktur rekursiv ist. Rekursion an sich verstehe ich, aber ich sehe noch keine allgemeine Regel, an der man erkennt, dass eine Datenstruktur rekursiv ist. Wenn ihr mir das vllt. erklären könntet, wäre ich euch sehr dankbar.

Das war's erstmal. Ich hoffe ich habe nichts vergessen und freue mich auf Antworten :)
 
G

Gast2

Gast
So haben wir für die Daten der Knoten ein Interface programmiert, an das wir die eigentliche Klasse mit den zu verwaltenden Daten angehängt haben. Meine Frage wäre jetzt, warum nimmt man ein Interface? Was hat das für Vorteile? Und warum verwendet man bei der eigentlichen Klasse, die die Daten verwaltet 'implements' und nicht 'extends', um vom Inteface "zu erben"? Ist das einfach so in Java festgelegt worden oder besteht die Möglichkeit beide Schlüsselwörter zu verwenden?
Man erbt nicht von Interfaces, man implementiert sie, daher das Stichwort
Code:
implements
. Bei Vererbung verwendet man
Code:
extends
.
Warum Interfaces? Das hat den Vorteil dass du irgendwann mal die Implementierung austauschen kannst ohne was am restlichen Programm ändern zu müssen. Dein Programm hat nur die Sicht auf das Interface, wie genau das implementiert ist, ist deinem Programm egal. ;)

Meine nächste Frage bezieht sich auf den Fakt, der uns vorgegeben wurde, dass die Liste eine rekursive Datenstruktur ist. Meine Frage ist jetzt, was allgemein kennzeichnend für eine rekursive Datenstruktur ist bzw. was das bedeutet, wenn eine Datenstruktur rekursiv ist. Rekursion an sich verstehe ich, aber ich sehe noch keine allgemeine Regel, an der man erkennt, dass eine Datenstruktur rekursiv ist. Wenn ihr mir das vllt. erklären könntet, wäre ich euch sehr dankbar.
Rekursive Datenstrukturen
 

Marco13

Top Contributor
Der Link enthält Beispiele, aber keine Definition im Sinne eines Unterscheidungskriteriums.
Die würde mich aber auch mal interessieren.
Das "Bauchgefühl" ist klar:
- Ein Knoten ist eine Liste
- "Ein Knoten vor einer Liste" ist eine Liste
oder
- Ein Knoten ist ein Baum
- "Ein Knoten and dem n Bäume hängen" ist ein Baum
Aber ein "Bauchgefühl" ist in einer Prüfung (manchmal Gold, aber meistens) einen Sch-dreck wert.

Analog dazu, dass man jede Rekursion in eine Iteration verwandeln kann, und es auch "triviale" und "unsinninge" Rekursionen gibt, kann man das ja kaum für eine echte Klassifikation verwenden... :bahnhof:
 
M

Mr.Käse

Gast
Danke für die Antwort auf die erste Frage, aber die zwiete wurde meiner Meinung nach immer noch nicht richtig beantwortet. Ich weiß, dass Bäume, Graphen, Listen, Schlangen, Stapel rekursive Datenstrukturen sind, möchte aber wissen, was sie als solche klassifiziert. Sind alle Datenstrukturen, die ein Referenz-Attribut auf ein Objekt der gleichen Klasse besitzen eine rekursive Datenstruktur?
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
V gutes Lernmaterial bezüglich formatierte Ausgaben in Java Allgemeine Java-Themen 2
D Bezüglich Design meines Codes Allgemeine Java-Themen 1
J NetBeans Frage bezüglich der Scanner-Klasse Allgemeine Java-Themen 6
E Wahrscheinlichkeit bezüglich der Auswahl eines farbigen Balls Allgemeine Java-Themen 8
S Stilfrage bezüglich Beans mit Collection-Properties Allgemeine Java-Themen 2
E Verständnisfrage bezüglich Threads Allgemeine Java-Themen 4
J Diverse Fragen bezüglich Jasper Allgemeine Java-Themen 3
W Frage bezüglich Codedesigns Allgemeine Java-Themen 4
S Strukturierungsfrage bezüglich Listeners Allgemeine Java-Themen 6
MiMa Filtern von TableView Liste Allgemeine Java-Themen 2
B Liste aller Kombintionen mit Einschränkungen Allgemeine Java-Themen 8
TheSepp Wie kann man Leerzeichen aus einer Array liste entfernen? Allgemeine Java-Themen 10
B Liste ändern während Iteration über Diese? Allgemeine Java-Themen 16
D Erste Schritte Liste erweitern Allgemeine Java-Themen 11
sserio Variablen Liste erstellt und ein Problem mit dem Index Allgemeine Java-Themen 6
L allgemein Strings händisch in Liste sortieren Allgemeine Java-Themen 47
M einfach verkettete Liste verstehen Allgemeine Java-Themen 23
Drachenbauer wie kann ich alle instanzen einer Klasse durchsehen, ohne, dass diese in einer Liste erzeugt wurden? Allgemeine Java-Themen 11
Gaudimagspam Skip Liste erstellen in Java Allgemeine Java-Themen 3
G Java Editor Löschen doppelter Zahlen einer Liste Allgemeine Java-Themen 2
bueseb84 Spring Boot Entity mit Liste Allgemeine Java-Themen 4
MiMa Werte in liste speichern? Allgemeine Java-Themen 3
Curtis_MC Collections Liste anhand mehrere Kriterien sortieren Allgemeine Java-Themen 6
K verkettete Liste Allgemeine Java-Themen 3
G Liste (UsageStats) sortieren (Android) Allgemeine Java-Themen 5
T Google Links in einer Liste Allgemeine Java-Themen 4
looparda Liste filtern nach Prädikaten verschiedener Typen Allgemeine Java-Themen 3
OSchriever Einfach verkettete Liste ändern Allgemeine Java-Themen 43
L Liste überschreibt alte Elemte Allgemeine Java-Themen 10
H Länge einer verketteten Liste Allgemeine Java-Themen 4
E Erstellen einer Liste mit einer maximalen Menge an Elementen Allgemeine Java-Themen 13
P Element einer Liste wurde hinzugefügt, aber es gibt keinen Zugriff Allgemeine Java-Themen 2
S Methoden Liste soll Methode aus innerer Klasse aufrufen Allgemeine Java-Themen 4
L Erste Schritte Liste von Datums filter nach Monate Allgemeine Java-Themen 4
Y Liste in Stream Packen Allgemeine Java-Themen 1
K Einfache Verkettete Liste mit Node Allgemeine Java-Themen 3
perlenfischer1984 Reflection : Element in generische Liste hinzufügen Allgemeine Java-Themen 4
perlenfischer1984 Liste mit generics zurück liefern Allgemeine Java-Themen 8
S Verkettete (Teil)Liste sortieren ( rekursiv bis n) Allgemeine Java-Themen 2
G Liste zwischen zwei Kalenderdaten erstellen Allgemeine Java-Themen 3
B Wie vergleiche ich Strings in einer Liste? Allgemeine Java-Themen 5
Viktim Threads Liste In unterschiedlichen Threads bearbeiten Allgemeine Java-Themen 23
A Collections Inhalt einer Liste mit Inhalt anderer Liste vergleichen ? Allgemeine Java-Themen 7
I Abstrakte Datentypen - Liste Allgemeine Java-Themen 9
D Datentypen Klassenattribut aus Objekt in generischer Liste Allgemeine Java-Themen 15
P Liste zu Objekt umwandeln Allgemeine Java-Themen 4
Z In die Liste kann ich nichts adden Allgemeine Java-Themen 16
C Liste checken auf MINDESTENS ein Objekt | Bukkit Allgemeine Java-Themen 3
M liste von listen anders ausgeben Allgemeine Java-Themen 1
B Per Buttonklicks einer Liste Wörter hinzufügen - Wie umsetzen? Allgemeine Java-Themen 11
H Liste sortieren anhand optionalem Property Allgemeine Java-Themen 3
L Liste führt sich nicht weiter Allgemeine Java-Themen 5
A Input/Output Liste der Dateien in einem Ordner in einer Jar Datei erhalten Allgemeine Java-Themen 11
J Fragen zu generischer doppelt verketteter Liste (bei fehlendem Grundverständnis) Allgemeine Java-Themen 1
B Prüfen, ob ein Element in der Liste nicht existiert Allgemeine Java-Themen 3
B Klassen JTable mit einer Liste Allgemeine Java-Themen 0
X HTTP Auslesen der Ergebnisse von einer Webseite und in eine Liste packen Allgemeine Java-Themen 1
A Auslesen einer Datei sowie ausgeben als Liste in App Allgemeine Java-Themen 5
E Liste löscht sich selbstständig Allgemeine Java-Themen 5
H Liste von Objekten generisch sortieren Allgemeine Java-Themen 0
D Liste anhand Standardnormalverteilung befüllen Allgemeine Java-Themen 1
M Threads synchroner Zugriff (add/delete/read) auf eine Liste Allgemeine Java-Themen 6
T Datentypen Eine Liste - verschiedenen Klassen - eine Abstracte Klasse Allgemeine Java-Themen 3
M Werte aus DB in Liste speichern ohne mehrfach speicherung Allgemeine Java-Themen 18
G Liste anzahl der gleichen Objekte Allgemeine Java-Themen 6
S Pattern.Match Suche: For Schleife einbinden und in Liste schreiben Allgemeine Java-Themen 3
O aus Liste ein beliebiges Element auswählen Allgemeine Java-Themen 7
J Liste aller Com-Ports - zweistellige Ports? Allgemeine Java-Themen 15
O MVC - wo Liste der ComboBox-Items ermitteln Allgemeine Java-Themen 3
MiMa Liste von Pfaden in eine textArea schreiben Allgemeine Java-Themen 7
K kontinuierlich aktuelle Bestellsystem-Liste mit farbigem Status Allgemeine Java-Themen 2
A Auswählbare Liste Allgemeine Java-Themen 2
D Sortieren von Liste zu unperformant Allgemeine Java-Themen 6
N Liste gesucht Allgemeine Java-Themen 2
Z Sortiertes Einfügen in doppelt verkettete Liste Allgemeine Java-Themen 5
S Probleme beim Auslesen einer Liste Allgemeine Java-Themen 8
O JSON String bauen aus Liste Allgemeine Java-Themen 2
M Über Liste verschiendene JComponents mit eigenem implementierten Interface ansprechen Allgemeine Java-Themen 7
T Hashmap mit geordneter/ungeordneter liste als Value Allgemeine Java-Themen 5
D Zugriff auf Array-Liste Allgemeine Java-Themen 19
S Threads Liste mit Objekten in Teillisten zerlegen und abarbeiten Allgemeine Java-Themen 3
R ThreadPool - vorhandene thread liste überprüfen bzw. aufräumen Allgemeine Java-Themen 3
pg1337 Liste füllen Allgemeine Java-Themen 2
U Große Liste von Strings mit indiziertem Zugriff Allgemeine Java-Themen 31
B Properties File Liste Allgemeine Java-Themen 3
Gossi Collections Liste zusammenfassen für JSP Allgemeine Java-Themen 4
Gossi Collections (Unbekannte) Liste Sortieren Allgemeine Java-Themen 10
T Collections Liste schnell/nebenläufig durchgehen Allgemeine Java-Themen 2
M Objekt aus Liste in Liste suchen/löschen Allgemeine Java-Themen 6
Q "Doppelte" Einträge einer Liste entfernen Allgemeine Java-Themen 14
C Exponentielle Verteilung in einer Liste Allgemeine Java-Themen 7
Nic.o liste der installierten Zertifikate ?! Allgemeine Java-Themen 3
T Liste mit GregorianCalendar-Objekten in List einlesen, mit Collection sortieren und ausgeben Allgemeine Java-Themen 3
S AWT Wie bekomme ich eine Liste aller chars in einem Font? Allgemeine Java-Themen 3
J Zeichenketten-Liste filtern Allgemeine Java-Themen 6
S Aus einer Liste<Oberklasse> alle Elemente die eine bestimmte Unterklasse von Oberklasse haben filter Allgemeine Java-Themen 8
K Liste aller implementierenden Klassen einer Oberklasse anzeigen Allgemeine Java-Themen 4
M Eintrag verschwindet aus Liste Allgemeine Java-Themen 3
E Objekte in einer Liste suchen. Allgemeine Java-Themen 4
I Über eine Liste iterieren und Objekte löschen. Wie löst man das sauber? Allgemeine Java-Themen 5

Ähnliche Java Themen

Neue Themen


Oben