Liste

starbug08

Mitglied
hallo leute hab hier ne kleine übungsaufgabe aber weiss nicht genau wie das hinbekommen soll mit dem print. hab hier mal den code, bin für jede hilfe dankbar.


Java:
class Link
{
//Attribute
int daten;
Link naechster;
//Konstruktor
Link(int daten, Link naechster)
{
this.daten = daten;
this.naechster = naechster;
}
}
public class Liste
{
//Attribute
protected Link anfang;
protected Link ende;
//Konstruktor
public Liste(int startLeer, int endeLeer)
{
anfang = new Link(startLeer, null);
ende = new Link (endeLeer, anfang);
anfang.naechster = ende;
}
public void einfuegenElement(int neuerWert)
{
Link neuerLink = new Link(neuerWert, ende);
Link bisherLetzter = ende.naechster;
bisherLetzter.naechster = neuerLink;
ende.naechster = neuerLink;
}


in der aufgabe heisst es man soll eine print methode erstellen die dann utereinander die eingefügten werte ausgibt. danke schon mal im vorraus
 

XHelp

Top Contributor
Du fängst beim 1. Element an, gibst aus und gehst zum nächsten... bis der nächste "null" ist.

Bist du dir sicher, dass der Rest stimmt? sieht etwas kreativ aus.
 

Andi_CH

Top Contributor
Du fängst beim 1. Element an, gibst aus und gehst zum nächsten... bis der nächste "null" ist.

Bist du dir sicher, dass der Rest stimmt? sieht etwas kreativ aus.

Die Methode einfuegen stelle ich auch erst mal in Frage (ich überprüfe das noch), aber warum soll der nächste jemals null werden???

Hättest du den Code gelesen hättest du gesehen, dass das als Ringbuffer aufgebaut ist.
Der Listenkonstruktor baut schon einen Ring.
Also loopen bis der selbstgebastelte Iterator wieder ende ist, dann aber nicht vergessen das ende auch noch auszugeben ....

print Methode: am besten ist es in Link die Methode toString zu überschreiben
in Liste dann auch und die loop über alle eingefügten elemente ....
im Hauptprogramm heisst es dann nur noch

Java:
System.out.println(mList);
 
Zuletzt bearbeitet:

Andi_CH

Top Contributor
Sieht zwar abenteuerlich aus, aber sogar die einfuegen Methode stimmt

Java:
	public static void main(String[] args) {
		Liste mList = new Liste(1, 4);
		System.out.println(mList);
		mList.einfuegenElement(2);
		System.out.println(mList);
		mList.einfuegenElement(3);
		System.out.println(mList);
	}

Code:
1
4

1
2
4

1
2
3
4

Java:
public class Liste {

	protected Link anfang;
	protected Link ende;

	public Liste(int startLeer, int endeLeer)
	{
		anfang = new Link(startLeer, null);
		ende = new Link (endeLeer, anfang);
		anfang.naechster = ende;
	}

	public void einfuegenElement(int neuerWert)
	{
		Link neuerLink = new Link(neuerWert, ende);
		Link bisherLetzter = ende.naechster;
		bisherLetzter.naechster = neuerLink;
		ende.naechster = neuerLink;
	}
	@Override
	public String toString() {
		Link pointer = anfang;
		String retVal = "";
// da fehlt was :-)
		return retVal;
	}
// falls es zwingend print heissen muss ...
	public void print(){
		System.out.println(this);
	}
}

Java:
public class Link {

	int daten;
	Link naechster;

	Link(int daten, Link naechster)
	{
		this.daten = daten;
		this.naechster = naechster;
	}
	@Override
	public String toString() {
		final String newLine = System.getProperty("line.separator");
		return "" + daten + newLine;
	}
}
 

starbug08

Mitglied
da ich leider immer noch lernen muss bin ich über eine aufgabe gestolpert. die beiden klassen link und liste sind genau die gleichen wie oben. die aufgabe ist diesmal das letzte element aus der liste zu entfernen,aber nicht das dummy element(also ende). ausserdem soll das gelöschte elemnt auf der konsole ausgegeben werden. ich hab hier mal meinen code und ich bekomme auch das richtige raus aber ich befürchte das die referenzen falsch sind.

Java:
public Link entfernen()
{
	Link aktuellerZeiger = ende.naechster;
	Link vorgängerAktuellerZeiger = ende.naechster.naechster;
	
	
	
	
	if(ende.naechster!=anfang)
	{
		vorgängerAktuellerZeiger.naechster = aktuellerZeiger.naechster;
		ende.naechster = vorgängerAktuellerZeiger;
		
		//System.out.println(aktuellerZeiger.daten);
		System.out.println(ende.naechster.naechster.daten);
		
	}else{
		System.out.println("null");
	}
 

Andi_CH

Top Contributor
Übernimm einfach meinen Code - es hat minimale Anpassungen drin, aber deiner war nahezu perfekt.
Einzig in Liste Zeile 24 musst du etwas ergänzen.

Ich poste aber lieber kompletten Code als nur Teile davon .... ist einfacher für die, die später mal auf diesen Thread stossen.
 

starbug08

Mitglied
ja danke du hast mir schon gut geholfen bei meinem ersten prob aber der neue code ist ne neue aufgabe. könnte man dies eventuell mit einem iterator lösen?
 

Andi_CH

Top Contributor
Hm, ich hab da schon eine Art Iterator drin - aber handgeschrieben

Java:
Link iterator = anfang;
While (iterator != ende) {
  machtEtwasmitDemIterator();
  iterator = iterator.naechstes;
}
// hier musst du noch das letzte Element behandeln ....

Aber mit "mein Code übernehmen" meine ich natürlich jetzt übernehmen - die toString Methode noch ausfüllen um zu verstehen wie es läuft- Dann schaffst du auch die nächste Aufgabe.

Fertige Iteratoren sind in diversen Listen implementiert, aber ich denke auf der Stufe ist die Meinung dass ihr selbst lernt wie das etwa funktioniert.

Versuch das mit dem toString in der Liste. Ich korrigier dir den Code dann schon.
 
Zuletzt bearbeitet:
Ähnliche Java Themen
  Titel Forum Antworten Datum
A Wie füge ich eine Liste so in eine andere Liste ein, dass der Index der Elemente derselbe bleibt? Java Basics - Anfänger-Themen 7
A Wort-Liste importieren Java Basics - Anfänger-Themen 11
G Liste schneller durchsuchen Java Basics - Anfänger-Themen 4
R Liste in Variable speichern Java Basics - Anfänger-Themen 6
R Liste und Arrays Java Basics - Anfänger-Themen 12
D 2 ArrayListen gleich sortieren bzw. eine Liste anhand einer anderen Sortieren Java Basics - Anfänger-Themen 6
J Ähnlichen String in Liste finden Java Basics - Anfänger-Themen 6
M Verkettete Liste Java Basics - Anfänger-Themen 1
M Vergleichen, ob eine Liste länger als andere ist Java Basics - Anfänger-Themen 6
H Liste nach String-Länge sortieren Java Basics - Anfänger-Themen 1
D remove Object von einer Liste von Obejcts Java Basics - Anfänger-Themen 3
E Elemente aus Liste entfernen und hinzufügen Java Basics - Anfänger-Themen 3
M Nullpointer beim befüllen meiner Liste im Object Java Basics - Anfänger-Themen 3
D Länge einer Liste aufrufen. Java Basics - Anfänger-Themen 19
B Objekt aus generalisierter Liste entfernen Java Basics - Anfänger-Themen 11
H Liste Knoten NullPointerException Java Basics - Anfänger-Themen 7
W Liste mit Listen in JTable darstellen Java Basics - Anfänger-Themen 1
N Was Passiert mit dem Namen einer Variable, wenn man diese einer Liste Hinzufügt Java Basics - Anfänger-Themen 16
E Suchfunktion in einer Liste Java Basics - Anfänger-Themen 39
T ungeordnete Werte-Paare in einer Liste Java Basics - Anfänger-Themen 7
L Hilfe! Liste mit Items werden ausgegeben aber nicht in zufälliger Reihenfolge Java Basics - Anfänger-Themen 6
berserkerdq2 Warum soll ich shuffle nutzen, um bei Rückgabewert Collection eine Liste zurückzugeben? Java Basics - Anfänger-Themen 3
sserio Wieso werden nicht alle Primzahlen bis 1000 in meine Liste gepackt ? Java Basics - Anfänger-Themen 8
sserio Liste erstellt und ein Problem mit dem Index Java Basics - Anfänger-Themen 8
f3mys Objektwerte in Liste speichern und wieder abrufen Java Basics - Anfänger-Themen 23
H Java verkettete Liste, Wert eines Index zurückgeben Java Basics - Anfänger-Themen 1
K Warum ist die binäre Suche bei der verketteten Liste nicht so effektiv? Java Basics - Anfänger-Themen 3
I 2D-Array Position der Liste ausgeben. Java Basics - Anfänger-Themen 2
I Liste von Infos von einer eigenen Annotation in Liste speichern Java Basics - Anfänger-Themen 0
P Doppelte werte in einer Liste zählen Java Basics - Anfänger-Themen 11
Dorfschmied Kartesisches Produkt von zwei Liste mit Hashmaps<String,String> erstellen Java Basics - Anfänger-Themen 4
Igig1 Autoparkplatz verkettete Liste erstes und letztes Auto Java Basics - Anfänger-Themen 13
thor_norsk Verkette Liste Java Basics - Anfänger-Themen 27
R Rückgabe: verkettete Liste Java Basics - Anfänger-Themen 2
R einfach verkettete Liste Java Basics - Anfänger-Themen 1
R einfach verkettete Liste Java Basics - Anfänger-Themen 12
O Doppelt verkette Liste Element löschen Java Basics - Anfänger-Themen 15
B GUI extension mit einer Liste verbinden Java Basics - Anfänger-Themen 1
B Verkettete Liste durchgehen und einzelne Elemente in neue Liste tun Java Basics - Anfänger-Themen 9
B Bin komplett am verzweifeln :( Verkettete Liste die Objekte hat Attribut auslesen Java Basics - Anfänger-Themen 14
M Java Liste streamen Java Basics - Anfänger-Themen 10
AmsananKING Aussortierung einer Liste Java Basics - Anfänger-Themen 8
A Objekte mit Parametern in eine Liste packen Java Basics - Anfänger-Themen 19
A Korrigierte <String> Liste zurückgeben Java Basics - Anfänger-Themen 22
S Kann nicht auf die Liste zugreifen mit der Methode!? Java Basics - Anfänger-Themen 3
B Datentyp für Einzelnes Objekt oder Liste Java Basics - Anfänger-Themen 9
alice98 Erste Schritte Liste erstellen ohne vorgefertigte Klassen Java Basics - Anfänger-Themen 1
J Doppelt verkette Liste ich bitte um Hilfe Java Basics - Anfänger-Themen 4
I Liste gruppieren nach Monat? Java Basics - Anfänger-Themen 5
districon Element in Liste einfügen Java Basics - Anfänger-Themen 1
B Hilfe bei Map Liste erstellen Java Basics - Anfänger-Themen 10
Y Einfügen in eine doppelt verkettete Liste Java Basics - Anfänger-Themen 8
Y Knoten an einem gegebenen Index aus einer Liste entfernen. Java Basics - Anfänger-Themen 6
H Daten aus einer Datei in eine Liste speichern Java Basics - Anfänger-Themen 23
Gaudimagspam Linked Liste Java Basics - Anfänger-Themen 4
Z Liste umkehren Java Basics - Anfänger-Themen 1
S Eine Liste kopieren Java Basics - Anfänger-Themen 13
java3690 Java- liste füllen ud die werte addieren Java Basics - Anfänger-Themen 13
java3690 Liste mit zufälligen zahlen füllen Java Basics - Anfänger-Themen 27
java3690 eine liste sortieren Java Basics - Anfänger-Themen 12
J Element aus Liste nehmen Java Basics - Anfänger-Themen 3
B JUnit 4: Wie man die eigene Liste testen kann [TDD] Java Basics - Anfänger-Themen 46
B Interface List - Objekt übergeben? Einzelnes Objekt geht, aber Liste nicht? Java Basics - Anfänger-Themen 4
P Was genau bringt mir es ein Array in eine Liste zu bringen Java Basics - Anfänger-Themen 3
A Doppelt verkettete Liste rückwärts ausgeben Java Basics - Anfänger-Themen 17
P Verschachtelte Array Liste Java Basics - Anfänger-Themen 2
H Liste speichern. Was lässt sich verbessern? Java Basics - Anfänger-Themen 7
P Performance Array und Liste Java Basics - Anfänger-Themen 13
M QuickSort und Liste Java Basics - Anfänger-Themen 6
N Methode um Objekte einer Liste hinzuzufügen Java Basics - Anfänger-Themen 1
B Summe von Property innerhalb einer Liste via Lambda Java Basics - Anfänger-Themen 1
V Collections int Werte in einer Liste sortieren Java Basics - Anfänger-Themen 23
B Neue Liste erstellen, wenn Objekte bestimmte Referenz hat / Gruppierung von Einträgen Java Basics - Anfänger-Themen 12
V_Fynn03 Beliebiges Element in einer Liste löschen (Java)(Lineare Datenstrukturen) Java Basics - Anfänger-Themen 9
L Baum aus Integer Liste erstellen Java Basics - Anfänger-Themen 0
CptK Koordinate in Liste suchen Java Basics - Anfänger-Themen 20
C Verschiedene Objekte in einer Liste speichern Java Basics - Anfänger-Themen 6
M Ausgabe einer Liste welche mehrere Stacks enthält Java Basics - Anfänger-Themen 3
D Doppelt Verkettete Zirkular-Liste Java Basics - Anfänger-Themen 1
L Liste in anderem Thread laden Java Basics - Anfänger-Themen 1
M Array liste Verdrehen Java Basics - Anfänger-Themen 8
A Verkettete Liste Java Basics - Anfänger-Themen 2
J Strings untereinander in einer Liste vergleichen Java Basics - Anfänger-Themen 18
B Liste von Tagen generieren ab einem bestimmten Datum und Endedatum Java Basics - Anfänger-Themen 4
S IndexOutOfBoundsException beim hinzufügen eines Elements zu einer Liste Java Basics - Anfänger-Themen 11
B Liste sortieren? Java Basics - Anfänger-Themen 4
O Anonyme Klasse einer Liste erstellen Java Basics - Anfänger-Themen 7
B SWAP List; Liste neu anordnen Java Basics - Anfänger-Themen 4
B CSS Klassen in eine Liste schreiben Java Basics - Anfänger-Themen 4
B Doppelt verkettete Liste implementieren Java Basics - Anfänger-Themen 8
L verkettete Liste Java Basics - Anfänger-Themen 15
scratchy1 doppelt verkettete Liste testen Java Basics - Anfänger-Themen 8
O ADT Liste z. B. Java Basics - Anfänger-Themen 15
B sortierte Liste Java Basics - Anfänger-Themen 4
O Knoten und Liste verarbeitung Java Basics - Anfänger-Themen 20
R Methoden Entferne alle identische Knoten (Typ String) aus verkettete Liste Java Basics - Anfänger-Themen 8
C Methoden Über eine einfach verkettete Liste Java Basics - Anfänger-Themen 8
J Eine Liste von Listen erstellen Java Basics - Anfänger-Themen 11
A Einträge aus Tupeln nach Regeln in Liste speichern Java Basics - Anfänger-Themen 8
Queiser Liste zurückgeben Java Basics - Anfänger-Themen 7

Ähnliche Java Themen

Neue Themen


Oben