Einzelnen Beitrag anzeigen

Benutzerbild von Tormentor32
Tormentor32

Registriert seit: 27. Okt 2005
Ort: Düsseldorf
369 Beiträge
 
Delphi XE5 Professional
 
#8

Re: Wert bestimmen ohne Format

  Alt 27. Apr 2007, 10:54
Typischer Anwendungsbereich wäre eine Liste, die man nach verschiedenen Kriterien verkettet.

Nehmen wir mal an, wir haben eine Liste von Schülern. Jeder Schüler hat verschiedene "Eigenschaften", Name, Vorname, Geburtstag, Adresse, Klasse, etc...

Das können wir der einfach in einem Record lösen:
Delphi-Quellcode:
type
  TSchueler = Record
    Name,Vorname: string;
    Geburtstag: TDate;
  end;
Das Prinzip der mehrfach verketteten Liste funktioniert so, dass Jeder Eintrag auf den nächsten zeigt. Wenn wir unsere Schüler also nach Geburtstag und nach Name ordenen wollen können, dann müssen wir folgendes machen
Delphi-Quellcode:
type
  PSchueler: ^TSchueler;
Und an unserem Record TSchueler müssen wir folgendes ändern:
Delphi-Quellcode:
type
  TSchueler = Record
    Name,Vorname: string;
    Geburtstag: TDate;
    NaechsterBeiGeburtstag,
    NaechsterBeiName: PSchueler;
  end;
Jetzt haben wir die Zeiger mit in den Record genommen.

Nach näherem Betrachten liegt der Vorteil gegenüber einem Array auf der Hand: Wir können Die Liste Sortieren, ohne dass wir die Einträge hin und her schieben müssen, das heißt, wenn unsere Liste 10000 Schüler hat, die man nach 10 Kriterien sortieren kann, dann dauert das, wenn man jeden Eintrag verschieben muss wesentlich länger! Bei der Zeigerliste müssen wir lediglich die Zeiger umbiegen, wenn wir einen neuen Schüler einfügen, oder einen Entfernen.

Ich hoffe ich konnte dir das näher bringen, bei Fragen: fragen!
Richard Mahr
  Mit Zitat antworten Zitat