Inhaltsverzeichnis

Linked Stack

Einen Stapel kann man folgendermaßen modellieren:

Das sieht also ganz ähnlich aus, wie bei der verketteten Liste. Auch der Stapel/Stack arbeitet mit einer Struktur von Knoten, die "aufeinander zeigen", er kann also wie die Liste beliebig viele Objekte verwalten. Der Stapel muss sich jedoch in seinem Attribut head nur eine Referenz merken - die auf den obersten Knoten des Stapels. Alle Operationen des Stacks finden immer auf diesem obersten Knoten statt:

Implementation

Kickoff

Zu implementieren sind also die Operationen push, pop, top und isEmpty. Hier: https://codeberg.org/qg-info-unterricht/bluej-linked-stack findest du eine BlueJ-Vorlage, in der du arbeiten kannst.

(A1) Konstruktor und Attribute

Erweitere die Klasse so, dass es sinnvoll möglich ist, ein neues Stack Objekt zu erzeugen.

push - Element auf den Stapel legen

Das folgende Schaubild veranschaulicht den Vorgang, wenn ein neues Element auf den Stapel gelegt werden soll.

(A2) Push

Implementiere und teste die Push-Methode.

pop - Element auf den Stapel legen

(A3) Pop Schaubild

Erstelle ein Schaubild wie oben, welches den Vorgang beim Entfernen eines Elements vom Stapel veranschaulicht.

(A4) Pop Methode

Implementiere und teste die Pop-Methode.

(A5) Vervollständigen

Vervollständige und teste die fehlenden Methoden.

Refaktorisieren: Private Knotenattribute

(A6) Vervollständigen

Passe deinen Stack und die Knoten-Klasse so an, dass die Knotenattribute "private" sind. Welche Methoden benötigst du dann in der Klasse Node? Wie wirkt sich das auf deinen übrigen Code in der Klasse LinkedList aus?

<<< Zurück zur Rückgängig-Funktion

Material

FilenameFilesizeLast modified
klassendiagramm.png30.2 KiB06.10.2021 20:11
push.png81.7 KiB06.10.2021 20:55
stack02.odp134.4 KiB06.10.2021 20:41
stack02.pdf137.8 KiB06.10.2021 20:41
stack03.png50.9 KiB06.10.2021 20:14