Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Algorithmen, Datenstrukturen und Klassendesign (https://www.delphipraxis.net/78-algorithmen-datenstrukturen-und-klassendesign/)
-   -   ADT Liste insert(inhat:T_inhalt) (https://www.delphipraxis.net/159325-adt-liste-insert-inhat-t_inhalt.html)

thiagojonas 23. Mär 2011 12:08

ADT Liste insert(inhat:T_inhalt)
 
Hallo liebe Freunde,

ich schreibe nächste woche mittwoch meine abiklausur in Informatik. :) Unteraderem kommen natürlich die ADT, Stapel, Schlange und Liste dran.

Stapel und schlange habe ich schon fertig gelernt und implementiert. Bei der Liste habe ich noch einige Probleme.

Hier die Anforderungen an uns: hier

So hier jetzt mein Problem: Laut vorgaben muss ich eine "insert" funktion machen, die folgendes kann:
Zitat:

Ein neues Listenelement mit dem angegebenen Inhalt wird angelegt und vor der aktuellen Position in
die Liste eingefügt. Der interne Positionszeiger steht auf dem neu eingefügten Element.
Mein Lösungsansatz:

Code:
 procedure TListe._insert (inhalt: Inhalt);
     var i:integer;
      begin
        inc(Zeiger);
        inc(aktuell);
        data[Zeiger] := inhalt;
      end;
Die Vorgabe sagt aber, dass die neuen Element vor dem aktuellen Knoten hinzugefügt werden müssen. Hier wird es aber immer oberhalb der Liste, ein neues Element hinzugefügt.

Wie kann ich das richtig machen?

Wie kann ich Abfragen ob der Zeiger auf dem letzen Listenelement steht?

Danke im voraus :)

DeddyH 23. Mär 2011 13:28

AW: ADT Liste insert(inhat:T_inhalt)
 
Zitat:

Die Vorgabe sagt aber, dass die neuen Element vor dem aktuellen Knoten hinzugefügt werden müssen. Hier wird es aber immer oberhalb der Liste, ein neues Element hinzugefügt.

...

Wie kann ich Abfragen ob der Zeiger auf dem letzen Listenelement steht?
Die Methoden, die Du dazu brauchst, stehen doch auch in der Anforderung.

thiagojonas 23. Mär 2011 13:59

AW: ADT Liste insert(inhat:T_inhalt)
 
Liste der Anhänge anzeigen (Anzahl: 1)
Lade mal die Datei hoch, soweit ich gekommen bin.

Habe für die Insert-Funktion eine Lösung durch rumspielen erhalten,warum das so ist, weiß ich noch nicht.

Außerdem füge ich hier das Elemnet oberhalb der aktuellen Position. Bei der vorgaben steht was von "vor" der aktuellen Position. Weiß nicht ob das damit gemeint ist.

Es fehlt mir nicht nur noch die function "endofList". Weiß noch nicht, wie ich das machen soll.

thiagojonas 23. Mär 2011 18:11

AW: ADT Liste insert(inhat:T_inhalt)
 
Liste der Anhänge anzeigen (Anzahl: 1)
Habe es jetzt selbst heraussgeraufen. Trotzdem Danke für die Hilfe!:-D

Anbei, für alle die es interesiert, das fertige Programm für die ADT Liste

daywalker9 23. Mär 2011 18:21

AW: ADT Liste insert(inhat:T_inhalt)
 
Ein Tipp noch.

Nicht auf
Delphi-Quellcode:
if List1._topOfTheList=false
testen. Einfach das = true/false weglassen. Wurde hier schon öfters mal diskutiert.

DeddyH 23. Mär 2011 18:59

AW: ADT Liste insert(inhat:T_inhalt)
 
Wobei false noch gar nicht so schlimm ist, wenn auch unfein.


Alle Zeitangaben in WEZ +1. Es ist jetzt 10:26 Uhr.

Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz