Einführung in die Informatik für Naturwissenschaftler und Ingenieure (alias Einführung in die Programmierung) (Vorlesung) Prof. Dr. Günter Rudolph Fakultät.

Slides:



Advertisements
Ähnliche Präsentationen
Klassen - Verkettete Liste -
Advertisements

Claudio Moraga; Gisbert Dittrich
Kapitel 3: Listen Lineare Liste: endliche Folge von Elementen eines Grundtyps (n>=0), leere Liste falls n=0 Listenelemente besitzen.
Synonyme: Stapel, Keller, LIFO-Liste usw.
Gliederung Motivation / Grundlagen Sortierverfahren
Java: Dynamische Datentypen
Vorlesung Informatik 2 Algorithmen und Datenstrukturen (05 – Elementare Datenstrukturen) Prof. Th. Ottmann.
Informatik II, SS 2008 Algorithmen und Datenstrukturen Vorlesung 6 Prof. Dr. Thomas Ottmann Algorithmen & Datenstrukturen, Institut für Informatik Fakultät.

EINI-I Einführung in die Informatik für Naturwissenschaftler und Ingenieure I Kapitel 9 Claudio Moraga; Gisbert Dittrich FBI Unido
Universität Dortmund, Lehrstuhl Informatik 1 EINI II Einführung in die Informatik für Naturwissenschaftler und Ingenieure.
EINI-I Einführung in die Informatik für Naturwissenschaftler und Ingenieure I Kapitel 7 Claudio Moraga, Gisbert Dittrich FBI Unido
EINI-I Einführung in die Informatik für Naturwissenschaftler und Ingenieure I Vorlesung 2 SWS WS 99/00 Gisbert Dittrich FBI Unido
EINI-I Einführung in die Informatik für Naturwissenschaftler und Ingenieure I Vorlesung 2 SWS WS 99/00 Gisbert Dittrich FBI Unido
EINI-I Einführung in die Informatik für Naturwissenschaftler und Ingenieure I Vorlesung 2 SWS WS 99/00 Gisbert Dittrich FBI Unido
EINI-I Einführung in die Informatik für Naturwissenschaftler und Ingenieure I Vorlesung 2 SWS WS 99/00 Gisbert Dittrich FBI Unido
EINI-I Einführung in die Informatik für Naturwissenschaftler und Ingenieure I Kapitel 10 Claudio Moraga; Gisbert Dittrich FBI Unido
Einführung in die Programmierung
Einführung in die Informatik für Naturwissenschaftler und Ingenieure (alias Einführung in die Programmierung) (Vorlesung) Prof. Dr. Günter Rudolph Fakultät.
Einführung in die Programmierung Wintersemester 2013/14 Prof. Dr. Günter Rudolph Lehrstuhl für Algorithm Engineering Fakultät für Informatik TU Dortmund.
Einführung in die Informatik für Naturwissenschaftler und Ingenieure
Einführung in die Informatik für Naturwissenschaftler und Ingenieure (alias Einführung in die Programmierung) (Vorlesung) Prof. Dr. Günter Rudolph Fachbereich.
Einführung in die Programmierung
Einführung in die Programmierung Wintersemester 2008/09 Prof. Dr. Günter Rudolph Lehrstuhl für Algorithm Engineering Fakultät für Informatik TU Dortmund.
Einführung in die Programmierung Wintersemester 2009/10 Prof. Dr. Günter Rudolph Lehrstuhl für Algorithm Engineering Fakultät für Informatik TU Dortmund.
Einführung in die Informatik für Naturwissenschaftler und Ingenieure
Einführung in die Programmierung
Einführung in die Informatik für Naturwissenschaftler und Ingenieure
Einführung in die Informatik für Naturwissenschaftler und Ingenieure
Einführung in die Informatik für Naturwissenschaftler und Ingenieure
Einführung in die Programmierung
Einführung in die Programmierung Wintersemester 2008/09 Prof. Dr. Günter Rudolph Lehrstuhl für Algorithm Engineering Fakultät für Informatik TU Dortmund.
Einführung in die Informatik für Naturwissenschaftler und Ingenieure (alias Einführung in die Programmierung) (Vorlesung) Prof. Dr. Günter Rudolph Fachbereich.
Einführung in die Programmierung Wintersemester 2008/09 Prof. Dr. Günter Rudolph Lehrstuhl für Algorithm Engineering Fakultät für Informatik TU Dortmund.
Einführung in die Informatik für Naturwissenschaftler und Ingenieure
Einführung in die Informatik für Naturwissenschaftler und Ingenieure
Einführung in die Programmierung Wintersemester 2008/09 Prof. Dr. Günter Rudolph Lehrstuhl für Algorithm Engineering Fakultät für Informatik TU Dortmund.
Einführung in die Informatik für Naturwissenschaftler und Ingenieure
Einführung in die Informatik für Naturwissenschaftler und Ingenieure (alias Einführung in die Programmierung) (Vorlesung) Prof. Dr. Günter Rudolph Fachbereich.
Einführung in die Programmierung Wintersemester 2009/10 Prof. Dr. Günter Rudolph Lehrstuhl für Algorithm Engineering Fakultät für Informatik TU Dortmund.
Einführung in die Informatik für Naturwissenschaftler und Ingenieure (alias Einführung in die Programmierung) (Vorlesung) Prof. Dr. Günter Rudolph Fachbereich.
Einführung in die Informatik für Naturwissenschaftler und Ingenieure (alias Einführung in die Programmierung) (Vorlesung) Prof. Dr. Günter Rudolph Fachbereich.
Einführung in die Informatik für Naturwissenschaftler und Ingenieure (alias Einführung in die Programmierung) (Vorlesung) Prof. Dr. Günter Rudolph Fachbereich.
Einführung in die Informatik für Naturwissenschaftler und Ingenieure (alias Einführung in die Programmierung) (Vorlesung) Prof. Dr. Günter Rudolph Fakultät.
Einführung in die Informatik für Naturwissenschaftler und Ingenieure (alias Einführung in die Programmierung) (Vorlesung) Prof. Dr. Günter Rudolph Fachbereich.
Einführung in die Informatik für Naturwissenschaftler und Ingenieure (alias Einführung in die Programmierung) (Vorlesung) Prof. Dr. Günter Rudolph Fachbereich.
Einführung in die Informatik für Naturwissenschaftler und Ingenieure (alias Einführung in die Programmierung) (Vorlesung) Prof. Dr. Günter Rudolph Fakultät.
Einführung in die Informatik für Naturwissenschaftler und Ingenieure (alias Einführung in die Programmierung) (Vorlesung) Prof. Dr. Günter Rudolph Fachbereich.
Einführung in die Informatik für Naturwissenschaftler und Ingenieure (alias Einführung in die Programmierung) (Vorlesung) Prof. Dr. Günter Rudolph Fachbereich.
Einführung in die Informatik für Naturwissenschaftler und Ingenieure (alias Einführung in die Programmierung) (Vorlesung) Prof. Dr. Günter Rudolph Fachbereich.
Einführung in die Informatik für Naturwissenschaftler und Ingenieure
Einführung in die Informatik für Naturwissenschaftler und Ingenieure (alias Einführung in die Programmierung) (Vorlesung) Prof. Dr. Günter Rudolph Fachbereich.
Einführung in die Informatik für Naturwissenschaftler und Ingenieure (alias Einführung in die Programmierung) (Vorlesung) Prof. Dr. Günter Rudolph Fachbereich.
Einführung in die Programmierung Wintersemester 2008/09 Prof. Dr. Günter Rudolph Lehrstuhl für Algorithm Engineering Fakultät für Informatik TU Dortmund.
Einführung in die Informatik für Naturwissenschaftler und Ingenieure (alias Einführung in die Programmierung) (Vorlesung) Prof. Dr. Günter Rudolph Fakultät.
Einführung in die Informatik für Naturwissenschaftler und Ingenieure (alias Einführung in die Programmierung) (Vorlesung) Prof. Dr. Günter Rudolph Fachbereich.
Einführung in die Informatik für Naturwissenschaftler und Ingenieure (alias Einführung in die Programmierung) (Vorlesung) Prof. Dr. Günter Rudolph Fachbereich.
Einführung in die Informatik für Naturwissenschaftler und Ingenieure (alias Einführung in die Programmierung) (Vorlesung) Prof. Dr. Günter Rudolph Fachbereich.
Einführung in die Informatik für Naturwissenschaftler und Ingenieure (alias Einführung in die Programmierung) (Vorlesung) Prof. Dr. Günter Rudolph Fachbereich.
Einführung in die Informatik für Naturwissenschaftler und Ingenieure (alias Einführung in die Programmierung) (Vorlesung) Prof. Dr. Günter Rudolph Fachbereich.
Einführung in die Informatik für Naturwissenschaftler und Ingenieure (alias Einführung in die Programmierung) (Vorlesung) Prof. Dr. Günter Rudolph Fakultät.
Einführung in die Informatik für Naturwissenschaftler und Ingenieure (alias Einführung in die Programmierung) (Vorlesung) Prof. Dr. Günter Rudolph Fachbereich.
Einführung in die Programmierung Wintersemester 2010/11 Prof. Dr. Günter Rudolph Lehrstuhl für Algorithm Engineering Fakultät für Informatik TU Dortmund.
Einführung in die Programmierung
Einführung in die Programmierung
Einführung in die Informatik für Naturwissenschaftler und Ingenieure (alias Einführung in die Programmierung) (Vorlesung) Prof. Dr. Günter Rudolph Fachbereich.
Institut für Wirtschaftsinformatik – Software Engineering, JKU Linz 1 Thomas Hilpold: Algorithmen und Datenstrukturen SS 2005 Mag.Th. Hilpold u. Dr. A.Stritzinger.
Einführung in die Informatik für Naturwissenschaftler und Ingenieure (alias Einführung in die Programmierung) (Vorlesung) Prof. Dr. Günter Rudolph Fachbereich.
Mag. Thomas Hilpold, Universität Linz, Institut für Wirtschaftsinformatik – Software Engineering 1 Algorithmen und Datenstrukturen 1 SS 2002 Mag.Thomas.
Tutorium Software-Engineering SS14 Florian Manghofer.
 Präsentation transkript:

Einführung in die Informatik für Naturwissenschaftler und Ingenieure (alias Einführung in die Programmierung) (Vorlesung) Prof. Dr. Günter Rudolph Fakultät für Informatik Lehrstuhl für Algorithm Engineering Wintersemester 2007/08

Rudolph: EINI (WS 2007/08) Kap. 8: Elementare Datenstrukturen2 Kapitel 8: Elementare Datenstrukturen Inhalt Definition ADT Keller ADT Schlange ADT Liste ADT Binärbaum …

Rudolph: EINI (WS 2007/08) Kap. 8: Elementare Datenstrukturen3 Wiederholung: ADT Schlange Lineare Datenstrukturen: Schlange (engl. queue) create: Schlange enq: Schlange x T Schlange deq: Schlange Schlange front: Schlange T empty: Schlange bool create: erzeugt leere Schlange enq: hängt Element ans Ende der Schlange deq: entfernt Kopf der Schlange front: gibt im Kopf der Schlange gespeichertes Element zurück empty: prüft, ob Schlange leer ist Implementierung mit statischen Speicher ersetzen durch dynamischen Speicher

Rudolph: EINI (WS 2007/08) Kap. 8: Elementare Datenstrukturen4 Wiederholung: Dynamischer Speicher Bauplan: Datentyp * Variable = new Datentyp;(Erzeugen) delete Variable;(Löschen) Bauplan für Arrays: Datentyp * Variable = new Datentyp [ Anzahl ] ;(Erzeugen) delete[] Variable;(Löschen) Achtung: Dynamisch erzeugte Objekte müssen auch wieder gelöscht werden! Keine automatische Speicherbereinigung!

Rudolph: EINI (WS 2007/08) Kap. 8: Elementare Datenstrukturen5 Kapitel 8: Elementare Datenstrukturen Vorüberlegungen für ADT Schlange mit dynamischen Speicher: Wir können bei der Realisierung der Schlange statt statischen (Array) nun dynamischen Speicher verwenden … Ansatz: new int[oldsize+1] … bringt uns das weiter? Größe kann zwar zur Laufzeit angegeben werden, ist aber dann fixiert! Falls maximale Größe erreicht, könnte man 1.größeres Array anlegen 2.Arraywerte ins größere Array kopieren und 3.kleineres Array löschen. ineffizient!

Rudolph: EINI (WS 2007/08) Kap. 8: Elementare Datenstrukturen6 Kapitel 8: Elementare Datenstrukturen Vorüberlegungen für ADT Schlange mit dynamischen Speicher: Objekt DatenfeldZeiger 0 zeigt auf Null (nichts): Nullpointer Start Ende Schlange Kopf +Schwanz der Schlange

Rudolph: EINI (WS 2007/08) Kap. 8: Elementare Datenstrukturen7 Kapitel 8: Elementare Datenstrukturen Implementierung: (Version 4) struct Objekt { T data;// Datenfeld Objekt *tail;// Zeiger auf Schwanz der Schlange }; struct Schlange { Objekt *sp;// Start Objekt *ep;// Ende }; Schlange *create() { Schlange *s = new Schlange; s->ep = 0; return s; } bool empty(Schlange *s) { return s->ep == 0; } Speicher für Schlange allokieren Initialisierung! Rückgabe des Zeigers auf Schlange true falls s->ep == 0, sonst false

Rudolph: EINI (WS 2007/08) Kap. 8: Elementare Datenstrukturen8 Kapitel 8: Elementare Datenstrukturen Implementierung: (Version 4) T front(Schlange *s) { if (!empty(s)) return (s->sp)->data; error(leer); } struct Objekt { T data;// Datenfeld Objekt *tail;// Zeiger auf Schwanz der Schlange }; struct Schlange { Objekt *sp;// Start Objekt *ep;// Ende }; void clear(Schlange *s) { while (!empty(s)) deq(s); } Was bedeutet s->sp->data ? identisch zu (*(*s).sp).data vorderstes Element entfernen bis Schlange leer

Rudolph: EINI (WS 2007/08) Kap. 8: Elementare Datenstrukturen9 Kapitel 8: Elementare Datenstrukturen Implementierung: (Version 4) void enq(Schlange *s, T x) { Objekt *obj = new Objekt; obj->data = x; obj->tail = 0; if (empty(s)) s->sp = obj; else s->ep->tail = obj; s->ep = obj; } struct Objekt { T data;// Datenfeld Objekt *tail;// Zeiger auf Schwanz der Schlange }; struct Schlange { Objekt *sp;// Start Objekt *ep;// Ende }; neues Objekt anlegen (dyn. Speicher) neues Objekt initialisieren neues Objekt vorne, falls Schlange leer sonst hinten anhängen Aktualisierung des Endezeigers

Rudolph: EINI (WS 2007/08) Kap. 8: Elementare Datenstrukturen10 Kapitel 8: Elementare Datenstrukturen Implementierung: (Version 4) void deq(Schlange *s) { if (empty(s))error(leer); Objekt *obj = s->sp; s->sp = s->sp->tail; if (s->sp == 0) s->ep = 0; delete obj; } struct Objekt { T data;// Datenfeld Objekt *tail;// Zeiger auf Schwanz der Schlange }; struct Schlange { Objekt *sp;// Start Objekt *ep;// Ende }; Zeiger auf zu löschendes Objekt retten Startzeiger auf 2. Element setzen falls kein 2. Element, dann Schlange leer ehemals 1. Element löschen

Rudolph: EINI (WS 2007/08) Kap. 8: Elementare Datenstrukturen11 Kapitel 8: Elementare Datenstrukturen int main() { Schlange *s = create(); if (empty(s)) cout << "Schlange leer" << endl; for (int i = 0; i < 10; i++) enq(s, i); if (!empty(s)) cout << "Schlange nicht mehr leer" << endl; cout << "vorderstes Element: " << front(s) << endl; while (!empty(s)) { cout << front(s) << " "; deq(s); } cout << endl; if (empty(s)) cout << "Schlange jetzt leer" << endl; for (i = 0; i < 100; i++) enq(s,i); if (!empty(s)) cout << "Schlange nicht mehr leer" << endl; clear(s); if (empty(s)) cout << "Schlange wieder leer" << endl; } Testprogramm!

Rudolph: EINI (WS 2007/08) Kap. 8: Elementare Datenstrukturen12 Kapitel 8: Elementare Datenstrukturen

Rudolph: EINI (WS 2007/08) Kap. 8: Elementare Datenstrukturen13 Kapitel 8: Elementare Datenstrukturen ADT Liste (1. Version) struct Liste { T data; Liste *next; }; Liste wird nur durch einen Zeiger auf ihren Listenkopf repräsentiert Operationen: create: Liste empty: Liste bool append: T x Liste Listehängt am Ende an prepend: T x Liste Listevor Kopf einfügen clear: Liste is_elem: T x Liste boolist Element enthalten?

Rudolph: EINI (WS 2007/08) Kap. 8: Elementare Datenstrukturen14 Kapitel 8: Elementare Datenstrukturen ADT Liste (1. Version) struct Liste { T data; Liste *next; }; Liste wird nur durch einen Zeiger auf ihren Listenkopf repräsentiert Liste *create() { return 0; } bool empty(Liste *liste) { return liste == 0; } void clear(Liste *liste) { if (empty(liste)) return; clear(liste->next); delete liste; } rekursives Löschen von hinten nach vorne Laufzeit: proportional zur Listenlänge Laufzeit: unabhängig von Listenlänge

Rudolph: EINI (WS 2007/08) Kap. 8: Elementare Datenstrukturen15 Kapitel 8: Elementare Datenstrukturen ADT Liste (1. Version) struct Liste { T data; Liste *next; }; bool is_elem(T x, Liste *liste) { if (liste == 0) return false; if (liste->data == x) return true; return is_elem(x, liste->next); } Liste *prepend(T x, Liste *liste) { Liste *L = new Liste; L->data = x; L->next = liste; return L; } rekursiver Durchlauf von vorne nach hinten Laufzeit: proportional zur Listenlänge Laufzeit: unabhängig von Listenlänge

Rudolph: EINI (WS 2007/08) Kap. 8: Elementare Datenstrukturen16 Kapitel 8: Elementare Datenstrukturen ADT Liste (1. Version) struct Liste { T data; Liste *next; }; Laufzeit: proportional zur Listenlänge iterativer Durchlauf von vorne nach hinten Liste *append(T x, Liste *liste) { Liste *tmp = liste; Liste *L = new Liste; L->data = x; L->next = 0; if (liste == 0) return L; while (liste->next != 0) liste = liste->next; liste->next = L; return tmp; } Zeiger auf Listenkopf retten

Rudolph: EINI (WS 2007/08) Kap. 8: Elementare Datenstrukturen17 Kapitel 8: Elementare Datenstrukturen ADT Liste (1. Version) Zusammenfassung: 1.Laufzeit von clear proportional zur Listenlänge 2.Laufzeit von is_elem proportional zur Listenlänge 3.Laufzeit von append proportional zur Listenlänge kann nicht verbessert werden, weil ja jedes Element gelöscht werden muss unproblematisch, weil nur selten aufgerufen kann bei dieser Datenstruktur nicht verbessert werden später verbessert durch ADT BinärBaum kann durch Veränderung der Implementierung verbessert werden zusätzlicher Zeiger auf das Ende der Liste

Rudolph: EINI (WS 2007/08) Kap. 8: Elementare Datenstrukturen18 Kapitel 8: Elementare Datenstrukturen ADT Liste (2. Version) struct Liste { Element *head; Element *foot; }; struct Element { T data; Element *next; }; Liste *create() { Liste *L = new Liste; L->head = L->foot = 0; return L; } bool empty(Liste *liste) { return liste->foot == 0; } Liste besteht aus 2 Zeigern: Zeiger auf Listenkopf (Anfang) Zeiger auf Listenfuß (Ende) Nutzdaten Zeiger auf nächstes Element Laufzeit: unabhängig von Listenlänge

Rudolph: EINI (WS 2007/08) Kap. 8: Elementare Datenstrukturen19 Kapitel 8: Elementare Datenstrukturen ADT Liste (2. Version) struct Liste { Element *head; Element *foot; }; struct Element { T data; Element *next; }; bool is_elem(T x, Liste *liste) { if (empty(liste)) return false; Element *elem = liste->head; while (elem != 0) { if (elem->data == x) return true; elem = elem->next; } return false; } iterativer Durchlauf von vorne nach hinten Laufzeit: proportional zur Listenlänge keine Verbesserung (OK)

Rudolph: EINI (WS 2007/08) Kap. 8: Elementare Datenstrukturen20 Kapitel 8: Elementare Datenstrukturen ADT Liste (2. Version) struct Liste { Element *head; Element *foot; }; struct Element { T data; Element *next; }; void clear(Liste *liste) { if (empty(liste)) return; Element *elem = liste->head; liste->head = elem->next; clear(liste); delete elem; } rekursives Löschen von hinten nach vorne Laufzeit: proportional zur Listenlänge keine Verbesserung (OK)

Rudolph: EINI (WS 2007/08) Kap. 8: Elementare Datenstrukturen21 Kapitel 8: Elementare Datenstrukturen ADT Liste (2. Version) struct Liste { Element *head; Element *foot; }; struct Element { T data; Element *next; }; Liste *prepend(T x, Liste *liste) { Element *elem = new Element; elem->data = x; elem->next = liste->head; if (empty(liste)) liste->foot = elem; liste->head = elem; return liste; } Laufzeit: unabhängig von Listenlänge

Rudolph: EINI (WS 2007/08) Kap. 8: Elementare Datenstrukturen22 Kapitel 8: Elementare Datenstrukturen ADT Liste (2. Version) struct Liste { Element *head; Element *foot; }; struct Element { T data; Element *next; }; Liste *append(T x, Liste *liste) { Element *elem = new Element; elem->data = x; elem->next = 0; if (empty(liste)) liste->head = elem; else liste->foot->next = elem; liste->foot = elem; } Laufzeit: unabhängig von Listenlänge Verbesserung!

Rudolph: EINI (WS 2007/08) Kap. 8: Elementare Datenstrukturen23 Kapitel 8: Elementare Datenstrukturen ADT Liste (2. Version) Zusammenfassung: 1.Laufzeit von clear proportional zur Listenlänge 2.Laufzeit von is_elem proportional zur Listenlänge 3.Laufzeit von append unabhängig von Listenlänge kann nicht verbessert werden, weil ja jedes Element gelöscht werden muss unproblematisch, weil nur selten aufgerufen kann bei dieser Datenstruktur nicht verbessert werden verbessern wir gleich durch ADT BinärBaum war proportional zur Listenlänge in 1. Version Verbesserung erzielt durch Veränderung der Implementierung

Rudolph: EINI (WS 2007/08) Kap. 8: Elementare Datenstrukturen24 Kapitel 8: Elementare Datenstrukturen ADT Binäre Bäume Vorbemerkungen: Zahlenfolge (z. B. 17, 4, 36, 2, 8, 19, 40, 6, 7, 37) soll gespeichert werden, um später darin suchen zu können Man könnte sich eine Menge A vorstellen mit Anfrage: Ist 40 A ? Mögliche Lösung: Zahlen in einer Liste speichern und nach 40 suchen … … aber: nicht effizient, weil im schlechtesten Fall alle Elemente überprüft werden müssen! Bessere Lösungen?

Rudolph: EINI (WS 2007/08) Kap. 8: Elementare Datenstrukturen25 Kapitel 8: Elementare Datenstrukturen ADT Binäre Bäume Beispiel: Zahlenfolge 17, 4, 36, 2, 8, 19, 40, 6, 7, kleiner: nach links größer: nach rechts z.B. Suche, ob 42 enthalten benötigt nur 3 Vergleiche bis zur Entscheidung false