Algorithmen und Datenstrukturen (für ET/IT)

Größe: px
Ab Seite anzeigen:

Download "Algorithmen und Datenstrukturen (für ET/IT)"

Transkript

1 Algorithmen und Datenstrukturen (für ET/IT) Wintersemester 2012/13 Dr. Tobias Lasser Computer Aided Medical Procedures Technische Universität München

2 Organisatorisches ausführliches Inhaltsverzeichnis auf Webseite verfügbar Kummerkasten ist anonym! Fragen (bei denen Sie Antworten erwarten) also bitte im Nachrichtenforum, oder per oder in Sprechstunden, Tutorfragestunden Tutorfragestunden diese Woche wieder normal 2

3 Wiederholung Definition Stack Stack (oder deutsch: Stapel, Keller) Ein Stack ist ein abstrakter Datentyp. Er beschreibt eine spezielle Listenstruktur nach dem Last In First Out (LIFO) Prinzip mit den Eigenschaften l oschen, einf ugen ist nur am Ende der Liste erlaubt, nur das letzte Element darf manipuliert werden. "pop" Piz za Piz za Piz za #3 #2 #1 neu e Piz za 8 3

4 Wiederholung Definition Stack (exakter) Stack S ist ein abstrakter Datentyp mit Operationen pop(s) liefert einen Wert push(s, x) wobei x ein Wert Definition Stack mit der Bedingung Stack (oder deutsch: iststapel, x WertKeller) und V abstrakte Variable, dann ist die Sequenz push(s,datentyp. x); store(v, pop(s)) aquivalent zu store(v, x) Ein Stack ist ein abstrakter Er beschreibt eine spezielle sowie derlast Operation Listenstruktur nach dem In First Out (LIFO) Prinzip mit den Eigenschaften top(s) liefert einen Wert l oschen, einf ugender istbedingung nur am Ende der Liste erlaubt, mit nur das letzte Element darf und manipuliert werden. ist x Wert V abstrakte Variable, dann ist die Sequenz push(s, x); store(v, top(s)); aquivalent zu push(s, x); store(v, x) "pop" 9 Piz za Piz za Piz za #3 #2 #1 neu e Piz za 8 3

5 Wiederholung Definition Queue Queue (oder deutsch: Warteschlange) Definition Eine Queue ist ein abstrakter Datentyp. Sie beschreibt eine spezielle Listenstruktur nach dem First In First Out (FIFO) Stack Prinzip (exakter) mit den Eigenschaften einf ugen ist nur am Ende der Liste erlaubt, Stack S ist ein abstrakter Datentyp mitam Operationen entfernen ist nur Anfang der Liste erlaubt. pop(s) liefert einen Wert push(s, x) wobei x ein Wert Definition Stack mit der Bedingung Stack (oder deutsch: iststapel, x WertKeller) und V abstrakte Variable, dann ist die Sequenz push(s,datentyp. x); store(v, pop(s)) aquivalent zu store(v, x) Ein Stack ist ein abstrakter Er beschreibt eine spezielle sowie derlast Operation Listenstruktur nach dem In FirstPerson Outverlässt (LIFO) Prinzip mit Schlange den Eigenschaften top(s) liefert einen Wert l oschen, einf ugender istbedingung nur am Ende der Liste erlaubt, mit Person stellt sich an 22 nur das letzte Element darf und manipuliert werden. ist x Wert V abstrakte Variable, dann ist die Sequenz push(s, x); store(v, top(s)); aquivalent zu push(s, x); store(v, x) "pop" 9 Piz za Piz za Piz za #3 #2 #1 neu e Piz za 8 3

6 Wiederholung Definition Queue Queue (oder deutsch: Warteschlange) Eine Queue ist ein abstrakter Datentyp. Sie beschreibt eine spezielle Listenstruktur nach dem First In First Out (FIFO) Definition Stack Prinzip (exakter) Definition Queue (exakter) mit den Eigenschaften ist ein Datentyp mit Operationen einf ugen ist Queue nur amqende derabstrakter Liste erlaubt, dequeue(q) liefert einen Wert Stack S ist ein abstrakter Datentyp mit Operationen entfernen ist nur am Anfang der Liste erlaubt. enqueue(q, x) wobei x ein Wert pop(s) liefert einen Wert push(s, x) wobei x ein Wert isempty(q) liefert true oder false Definition Stack mit der Bedingung initialize liefert eine Queue Instanz und mit dann Bedingungen Stack (oder deutsch: iststapel, x WertKeller) und V abstrakte Variable, ist die Sequenz istspezielle push(s,datentyp. x); store(v, pop(s)) aquivalent zu store(v, x) Variable und Q eine leere Queue, x Wert, V abstrakte Ein Stack ist ein abstrakter Er beschreibt eine dann mit ist die Sequenz enqueue(q, x); store(v, dequeue(q)) sowie derlast Operation Listenstruktur nach dem In FirstPerson Outverlässt (LIFO) Prinzip Schlange Person stellt sich an aquivalent zu store(v, x) den Eigenschaften top(s) liefert einen Wert sind x,y Werte, V abstrakte Variable und Q eine leere Queue, l oschen, einf ugender istbedingung nur am Ende der Liste erlaubt, mit dann ist die Sequenz enqueue(q, x); enqueue(q, y); 22 store(v, nur das letzte Element darf und manipuliert werden. ist x Wert V abstrakte Variable, dann ist die Sequenz zu store(v, x); enqueue(q, y) dequeue(q)) aquivalent push(s, x); store(v, top(s)); aquivalent zu initialize() 6= Q f ur jede Queue Q push(s, x); store(v, x) "pop" isempty(initialize()) == true isempty(enqueue(q, x)) == false 9 Piz za Piz za Piz za 24 #3 #2 #1 neu e Piz za 8 3

7 Programm heute 1 Einführung 2 Mathematische Grundlagen 3 Elementare Datenstrukturen 4 Grundlagen der Korrektheit von Algorithmen Motivation und Spezifikation Verifikation Beispiel: Insertion Sort 4

8 Beispiele für Fehler I 1996: Explosion der Ariane 5 Rakete mit 4 Satelliten an Bord Schaden: ca. 500 Millionen Dollar Ursache: Wert der horizontalen Geschwindigkeit von 64 Bit Floating Point Zahl (double) konvertiert auf 16 Bit Ganzzahl (signed short) Zahl grösser als 2 15 = overflow Zusammenbruch des Lenksystems Backup-Rechner verwendet gleiches Programm, selber Fehler Selbstzerstörung nach 36.7 Sekunden Flugzeit Annahme dass Rakete nie so schnell fliegen wird... 5

9 Beispiele für Fehler II 1995: Ausfall Stellwerk Hamburg-Altona Schaden: 2 Tage kein Schienenverkehr in Hamburg-Altona, 2 Monate Notfahrplan Ursache: Stack-Overflow neues zentrales, computerisiertes Stellwerk für 62.6 Millionen D-Mark von Siemens 3.5kB Stack für Stellbefehle (als sequentielle Liste) zu klein schon für normalen Verkehr overflow Fehlerbehandlungsroutine fehlerhaft Endlosschleife 6

10 Beispiele für Fehler III : Therac-25 Maschine zur Strahlentherapie Schaden: 3 Todesfälle durch Strahlenüberdosis Ursache: race condition in Software-Sperre für Strahl (race condition: Ergebnis einer Operation hängt vom zeitlichen Verhalten der Einzeloperationen ab, siehe Multitasking) Overflow in 8 Bit Test-Zähler zusammen mit Benutzereingabe deaktivieren Software-Sperre für Strahl unkontrollierte Bestrahlung mit bis zu 100-facher Dosis Gray Dosis statt 2 Gray, ab 10 Gray tödlich mind. 3 Personen sterben an Strahlenüberdosis 7

11 Relative Korrektheit Die Korrektheit eines Algorithmus bezieht sich immer auf die Spezifikation dessen, was er tun soll. Korrektheit ist relativ Algorithmus kann nicht an sich als korrekt bewiesen werden, sondern nur in Bezug auf Spezifikation Spezifikation: eindeutige Festlegung der berechneten Funktion bzw. des Terminierungsverhaltens einer Softwarekomponente 8

12 Nachweis der Korrektheit Nachweis der Korrektheit durch Verifikation: formaler, mathematischer Beweis, dass Algorithmus korrekt bezüglich formaler Spezifikation erfordert Formalisierung der Algorithmensprache und Spezifikation Validation: nicht-formaler Nachweis der Korrektheit etwa durch systematisches Testen in der Regel kein 100%ig sicherer Nachweis der Korrektheit! 9

13 Verifikation vs. Validation E.W. Dijkstra ( ): Testing shows the presence, not the absence of bugs Analogie zur Mathematik: Spezifikation: entspricht Satz Verifikation: Beweis des Satzes Validation: Ausprobieren an Beispielwerten 10

14 Programm heute 1 Einführung 2 Mathematische Grundlagen 3 Elementare Datenstrukturen 4 Grundlagen der Korrektheit von Algorithmen Motivation und Spezifikation Verifikation Beispiel: Insertion Sort 11

15 Vor- und Nachbedingungen Vor- und Nachbedingungen: Methode zur Spezifikation von gewünschten Eigenschaften von Algorithmen {VOR ANW {NACH {VOR: Aussage über Zustand vor Ausführung von ANW {NACH: Aussage über Zustand nach Ausführung von ANW 12

16 Vor- und Nachbedingungen Vor- und Nachbedingungen: Methode zur Spezifikation von gewünschten Eigenschaften von Algorithmen {VOR ANW {NACH {VOR: Aussage über Zustand vor Ausführung von ANW {NACH: Aussage über Zustand nach Ausführung von ANW Bedeutung: Gilt die Vorbedingung {VOR unmittelbar vor Ausführung von ANW und terminiert ANW so gilt die Nachbedingung {NACH unmittelbar nach Ausführung von ANW 12

17 Vor- und Nachbedingung {VOR ANW {NACH Sonderfälle: terminiert ANW nicht, so ist Aussage immer wahr egal wie {VOR, {NACH aussehen gilt {VOR nicht, so ist Aussage auch immer wahr egal ob ANW terminiert oder ob {NACH gilt 13

18 Vor- und Nachbedingung: Beispiele I Aussage ist wahr {X==0 X = X+1 {X==1 14

19 Vor- und Nachbedingung: Beispiele I Aussage ist wahr Aussage ist wahr {X==0 X = X+1 {X==1 {true X = Y {X==Y 14

20 Vor- und Nachbedingung: Beispiele I Aussage {X==0 X = X+1 {X==1 ist wahr Aussage {true X = Y {X==Y ist wahr Aussage {Y==a X = Y {X==a Y==a ist wahr für alle a Z 14

21 Vor- und Nachbedingung: Beispiele II Aussage {X==a Y==b a b X = Y; Y = X {X==b Y==a ist falsch für alle a, b Z! (nach erstem Schritt haben X, Y beide Wert b - typischer Fehler bei Wertetausch!) 15

22 Vor- und Nachbedingung: Beispiele II Aussage {X==a Y==b a b X = Y; Y = X {X==b Y==a ist falsch für alle a, b Z! (nach erstem Schritt haben X, Y beide Wert b - typischer Fehler bei Wertetausch!) Aussage {X==a Y==b Z = X; X = Y; Y = Z {X==b Y==a ist wahr für alle a, b Z (korrekter Wertetausch mit Hilfsvariable Z) 15

23 Vor- und Nachbedingung: Beispiele III Aussage {false ANW {NACH ist wahr für alle ANW und NACH, da Vorbedingung falsch 16

24 Vor- und Nachbedingung: Beispiele III Aussage {false ANW {NACH ist wahr für alle ANW und NACH, da Vorbedingung falsch Aussage {true ANW {false ist genau dann wahr, wenn ANW nicht terminiert 16

25 Vor- und Nachbedingung: Beispiele III Aussage {false ANW {NACH ist wahr für alle ANW und NACH, da Vorbedingung falsch Aussage {true ANW {false ist genau dann wahr, wenn ANW nicht terminiert Aussage {X==a while X 0 do X = X-1 end {X==0 ist wahr für alle a Z (auch für a < 0, da dann while-schleife nicht terminiert!) 16

26 Partielle Korrektheit Partielle Korrektheit Ein Programm mit Anweisungen ANW sowie Vorbedingung {VOR und Nachbedingung {NACH heißt partiell korrekt bezüglich VOR, NACH genau dann, wenn wahr ist. {VOR ANW {NACH 17

27 Partielle Korrektheit Partielle Korrektheit Ein Programm mit Anweisungen ANW sowie Vorbedingung {VOR und Nachbedingung {NACH heißt partiell korrekt bezüglich VOR, NACH genau dann, wenn wahr ist. {VOR ANW {NACH Das Programm heißt total korrekt bezüglich VOR, NACH genau dann, wenn es partiell korrekt ist bezüglich VOR, NACH ist und ANW immer dann terminiert, wenn VOR gilt. 17

28 Bausteine von Algorithmen Wiederholung: Bausteine von Algorithmen Elementarer Verarbeitungsschritt (z.b. Zuweisung an Variable) Sequenz (elementare Schritte nacheinander) Bedingter Verarbeitungsschritt (z.b. if/else) Wiederholung (z.b. while-schleife) 18

29 Korrektheit von Anweisungstypen I Elementarer Verarbeitungsschritt α {VOR α {NACH 19

30 Korrektheit von Anweisungstypen I Elementarer Verarbeitungsschritt α {VOR α {NACH Sequenz α; β {VOR α; β {NACH wird gezeigt mittels Zwischenbedingung MITTE, also und {VOR α {MITTE {MITTE β {NACH 19

31 Korrektheit von Anweisungstypen II Bedingter Verarbeitungsschritt wird gezeigt mittels und {VOR if (B) { α else { β {NACH {VOR B α {NACH {VOR B β {NACH zeige also dass NACH gilt, egal welcher Zweig ausgeführt wird! 20

32 Korrektheit von Anweisungstypen III Wiederholung {VOR while (B) { β {NACH wird gezeigt mittels Schleifeninvariante P: 1 prüfe, daß VOR P (Vorbedingung garantiert Schleifeninvariante bei Eintritt in Schleife) 2 prüfe, daß {P B β {P (wenn Schleife durchlaufen, bleibt Schleifeninvariante wahr) 3 prüfe, daß {P B NACH (Nachbedingung muß nach Verlassen der Schleife gelten) 21

33 Verifikation: Beispiel I Gauss sche Summenformel Sei n N. Dann gilt n = n i = i=1 n(n + 1) 2 22

34 Verifikation: Beispiel I Gauss sche Summenformel Sei n N. Dann gilt n = n i = i=1 n(n + 1) 2 Algorithmus: { n > 0 sum = 0; i = 0; while (i < n) { i = i + 1; sum = sum + i; { sum == n*(n+1)/2 22

35 Verifikation: Beispiel II Sequenz mit Zwischenbedingung: { n > 0 sum = 0; Algorithmus: { n > 0 sum = 0; i = 0; while (i < n) { i = i + 1; sum = sum + i; { sum == n*(n+1)/2 23

36 Verifikation: Beispiel II Sequenz mit Zwischenbedingung: { n > 0 sum = 0; { n > 0 sum == 0 Algorithmus: { n > 0 sum = 0; i = 0; while (i < n) { i = i + 1; sum = sum + i; { sum == n*(n+1)/2 23

37 Verifikation: Beispiel II Sequenz mit Zwischenbedingung: { n > 0 sum = 0; { n > 0 sum == 0 i = 0; Algorithmus: { n > 0 sum = 0; i = 0; while (i < n) { i = i + 1; sum = sum + i; { sum == n*(n+1)/2 23

38 Verifikation: Beispiel II Sequenz mit Zwischenbedingung: { n > 0 sum = 0; { n > 0 sum == 0 i = 0; { n > 0 sum == 0 i == 0 Algorithmus: { n > 0 sum = 0; i = 0; while (i < n) { i = i + 1; sum = sum + i; { sum == n*(n+1)/2 23

39 Verifikation: Beispiel III Wiederholung mit Invariante: { n > 0 sum == 0 i == 0 while (i < n) { i = i + 1; sum = sum + i; { sum == n*(n+1)/2 Passende Invariante P? Algorithmus: { n > 0 sum = 0; i = 0; while (i < n) { i = i + 1; sum = sum + i; { sum == n*(n+1)/2 24

40 Verifikation: Beispiel III Wiederholung mit Invariante: { n > 0 sum == 0 i == 0 while (i < n) { i = i + 1; sum = sum + i; { sum == n*(n+1)/2 Passende Invariante P? Algorithmus: { n > 0 sum = 0; i = 0; while (i < n) { i = i + 1; sum = sum + i; { sum == n*(n+1)/2 P = ( sum == i*(i+1)/2 i <= n ) 24

41 Verifikation: Beispiel IV Prüfe: 1 {VOR {P es ist i==0, also i<=n, und sum==0*1/2==0 Wiederholung mit Invariante: { n > 0 sum == 0 i == 0 while (i < n) { i = i + 1; sum = sum + i; { sum == n*(n+1)/2 Invariante P: P = (sum == i*(i+1)/2 i <= n) 25

42 Verifikation: Beispiel IV Prüfe: 1 {VOR {P es ist i==0, also i<=n, und sum==0*1/2==0 2 {P B β {P es ist i<n, also nach i=i+1 immer noch i<=n Wiederholung mit Invariante: { n > 0 sum == 0 i == 0 while (i < n) { i = i + 1; sum = sum + i; { sum == n*(n+1)/2 Invariante P: P = (sum == i*(i+1)/2 i <= n) 25

43 Verifikation: Beispiel IV Prüfe: 1 {VOR {P es ist i==0, also i<=n, und sum==0*1/2==0 2 {P B β {P es ist i<n, also nach i=i+1 immer noch i<=n, und für sum gilt sum= i(i+1) 2 +(i+1)== (i+1)*(i+2) 2 Wiederholung mit Invariante: { n > 0 sum == 0 i == 0 while (i < n) { i = i + 1; sum = sum + i; { sum == n*(n+1)/2 Invariante P: P = (sum == i*(i+1)/2 i <= n) 25

44 Verifikation: Beispiel IV Prüfe: 1 {VOR {P es ist i==0, also i<=n, und sum==0*1/2==0 2 {P B β {P es ist i<n, also nach i=i+1 immer noch i<=n, und für sum gilt sum= i(i+1) 2 +(i+1)== (i+1)*(i+2) 2 3 {P B {NACH es ist P B P!(i<n) Wiederholung mit Invariante: { n > 0 sum == 0 i == 0 while (i < n) { i = i + 1; sum = sum + i; { sum == n*(n+1)/2 Invariante P: P = (sum == i*(i+1)/2 i <= n) 25

45 Verifikation: Beispiel IV Prüfe: 1 {VOR {P es ist i==0, also i<=n, und sum==0*1/2==0 2 {P B β {P es ist i<n, also nach i=i+1 immer noch i<=n, und für sum gilt sum= i(i+1) 2 +(i+1)== (i+1)*(i+2) 2 3 {P B {NACH es ist P B P!(i<n) sum== i(i+1) 2 i<=n!(i<n) Wiederholung mit Invariante: { n > 0 sum == 0 i == 0 while (i < n) { i = i + 1; sum = sum + i; { sum == n*(n+1)/2 Invariante P: P = (sum == i*(i+1)/2 i <= n) 25

46 Verifikation: Beispiel IV Prüfe: 1 {VOR {P es ist i==0, also i<=n, und sum==0*1/2==0 2 {P B β {P es ist i<n, also nach i=i+1 immer noch i<=n, und für sum gilt sum= i(i+1) 2 +(i+1)== (i+1)*(i+2) 2 3 {P B {NACH es ist P B P!(i<n) sum== i(i+1) 2 i<=n!(i<n) sum== i(i+1) 2 i==n Wiederholung mit Invariante: { n > 0 sum == 0 i == 0 while (i < n) { i = i + 1; sum = sum + i; { sum == n*(n+1)/2 Invariante P: P = (sum == i*(i+1)/2 i <= n) 25

47 Verifikation: Beispiel IV Prüfe: 1 {VOR {P es ist i==0, also i<=n, und sum==0*1/2==0 2 {P B β {P es ist i<n, also nach i=i+1 immer noch i<=n, und für sum gilt sum= i(i+1) 2 +(i+1)== (i+1)*(i+2) 2 3 {P B {NACH es ist P B P!(i<n) sum== i(i+1) 2 i<=n!(i<n) sum== i(i+1) 2 i==n sum== n(n+1) 2 Wiederholung mit Invariante: { n > 0 sum == 0 i == 0 while (i < n) { i = i + 1; sum = sum + i; { sum == n*(n+1)/2 Invariante P: P = (sum == i*(i+1)/2 i <= n) 25

48 Verifikation Verifikation ist manuell sehr aufwendig in Praxis daher leider sehr selten eingesetzt Vorgang lässt sich weitgehend automatisieren Programm-Verifizierer Programm mit Vor- und Nachbedingungen Schleifeninvarianten müssen Invarianten haben nur möglich mit eingeschränkten Programmiersprachen z.b. Lightweight Java an der TUM: Programmsystem Isabelle (Informatik) 26

49 Programm heute 1 Einführung 2 Mathematische Grundlagen 3 Elementare Datenstrukturen 4 Grundlagen der Korrektheit von Algorithmen Motivation und Spezifikation Verifikation Beispiel: Insertion Sort 27

50 Insertion Sort Insertion Sort: Sortieren durch direktes Einfügen 28

51 Beschreibung von Insertion Sort Beschreibung in Vorlesung durch C-ähnlichen Pseudocode: Input: Feld A[0..n-1] von n natürlichen Zahlen Output: Feld A aufsteigend sortiert InsertionSort(A): for j=1 to länge(a)-1 { key = A[j]; // füge A[j] in sortierte Liste A[0..j-1] ein i = j-1; while (i >= 0 && A[i] > key) { A[i+1] = A[i]; i = i-1; A[i+1] = key; 29

52 Pseudocode Konventionen I Einrücken und geschweifte Klammern {, kennzeichnen Blockstruktur Beispiel: for j=1 to länge(a)-1 { key = A[j]; // füge A[j] in sortierte // Liste A[0..j-1] ein i = j-1; while (i >= 0 && A[i] > key) { A[i+1] = A[i]; i = i-1; A[i+1] = key; 30

53 Pseudocode Konventionen I Einrücken und geschweifte Klammern {, kennzeichnen Blockstruktur Sequenz durch Semikolon ; Beispiel: for j=1 to länge(a)-1 { key = A[j]; // füge A[j] in sortierte // Liste A[0..j-1] ein i = j-1; while (i >= 0 && A[i] > key) { A[i+1] = A[i]; i = i-1; A[i+1] = key; 30

54 Pseudocode Konventionen I Einrücken und geschweifte Klammern {, kennzeichnen Blockstruktur Sequenz durch Semikolon ; // bedeutet Rest der Zeile ist Kommentar (wird nicht ausgeführt) Beispiel: for j=1 to länge(a)-1 { key = A[j]; // füge A[j] in sortierte // Liste A[0..j-1] ein i = j-1; while (i >= 0 && A[i] > key) { A[i+1] = A[i]; i = i-1; A[i+1] = key; 30

55 Pseudocode Konventionen I Einrücken und geschweifte Klammern {, kennzeichnen Blockstruktur Sequenz durch Semikolon ; // bedeutet Rest der Zeile ist Kommentar (wird nicht ausgeführt) Wert-Zuweisung, z.b. x=5 weist der Variable x den Wert 5 zu Beispiel: for j=1 to länge(a)-1 { key = A[j]; // füge A[j] in sortierte // Liste A[0..j-1] ein i = j-1; while (i >= 0 && A[i] > key) { A[i+1] = A[i]; i = i-1; A[i+1] = key; 30

56 Pseudocode Konventionen I Einrücken und geschweifte Klammern {, kennzeichnen Blockstruktur Sequenz durch Semikolon ; // bedeutet Rest der Zeile ist Kommentar (wird nicht ausgeführt) Wert-Zuweisung, z.b. x=5 weist der Variable x den Wert 5 zu Beispiel: for j=1 to länge(a)-1 { key = A[j]; // füge A[j] in sortierte // Liste A[0..j-1] ein i = j-1; while (i >= 0 && A[i] > key) { A[i+1] = A[i]; i = i-1; A[i+1] = key; Feld A[0..n-1], Zugriff auf i-tes Element A[i] mit Index i (meist 0-basiert!) A[0..n-1] bezeichnet die Elemente A[0], A[1],..., A[n-1] 30

57 Pseudocode Konventionen II for-schleife: for j=wert1 to Wert2 {... Variable j nimmt schrittweise die Werte von Wert1 bis Wert2 an, jedes Mal wird Anweisung des Schleifenkörpers (... ) ausgeführt Am Ende der Schleife hat j den Wert Wert2+1 Beispiel: for j=1 to länge(a)-1 { key = A[j]; // füge A[j] in sortierte // Liste A[0..j-1] ein i = j-1; while (i >= 0 && A[i] > key) { A[i+1] = A[i]; i = i-1; A[i+1] = key; 31

58 Pseudocode Konventionen II for-schleife: for j=wert1 to Wert2 {... Variable j nimmt schrittweise die Werte von Wert1 bis Wert2 an, jedes Mal wird Anweisung des Schleifenkörpers (... ) ausgeführt Am Ende der Schleife hat j den Wert Wert2+1 Beispiel: for j=1 to länge(a)-1 { key = A[j]; // füge A[j] in sortierte // Liste A[0..j-1] ein i = j-1; while (i >= 0 && A[i] > key) { A[i+1] = A[i]; i = i-1; A[i+1] = key; while-schleife: while (Bedingung) {... Führt Schleifenkörper (... ) aus, solange Bedingung erfüllt ist 31

59 Pseudocode Konventionen III if-abfrage: if (Bedingung) {... else {... Verzweigung im Code anhand Bedingung. Falls Bedingung nicht erfüllt, kennzeichnet else den Zweig, der gewählt wird Beispiel: i=3; if (i==0) { x=0; else { x=2; print(x); 32

60 Pseudocode Konventionen III if-abfrage: if (Bedingung) {... else {... Verzweigung im Code anhand Bedingung. Falls Bedingung nicht erfüllt, kennzeichnet else den Zweig, der gewählt wird Beispiel: i=3; if (i==0) { x=0; else { x=2; print(x); print(x) Anweisung gibt Wert von Variable x aus 32

61 Insertion Sort: Ablauf Beispielablauf: Eingabe: A = 6, 3, 5, 7, 2, 4 j key A[1..j-1] i InsertionSort(A): for j=1 to länge(a)-1 { key = A[j]; // füge A[j] in sortierte // Liste A[0..j-1] ein i = j-1; while (i >= 0 && A[i] > key) { A[i+1] = A[i]; i = i-1; A[i+1] = key; 33

62 Insertion Sort: Ablauf

63 Insertion Sort: Verifikation Entscheidendes Kriterium: Schleifen-Invariante P der for Schleife P = Teilfeld A[0..j-1] besteht aus den ursprünglich in A[0..j-1] enthaltenen Werten und A[0..j-1] ist geordnet Prüfe: 1 Anfang j=1: Feld A[0..j-1] enthält nur ein Element A[0], ist sortiert 35

64 Insertion Sort: Verifikation Entscheidendes Kriterium: Schleifen-Invariante P der for Schleife P = Teilfeld A[0..j-1] besteht aus den ursprünglich in A[0..j-1] enthaltenen Werten und A[0..j-1] ist geordnet Prüfe: 1 Anfang j=1: Feld A[0..j-1] enthält nur ein Element A[0], ist sortiert 2 aktuelles Element mit Wert key, die Werte A[j-1], A[j-2],... werden jeweils eine Position nach rechts verschoben, bis korrekte Position A[i] gefunden für aktuelles Element, Element wird dort eingefügt Feld A[0..j-1] sortiert 35

65 Insertion Sort: Verifikation Entscheidendes Kriterium: Schleifen-Invariante P der for Schleife P = Teilfeld A[0..j-1] besteht aus den ursprünglich in A[0..j-1] enthaltenen Werten und A[0..j-1] ist geordnet Prüfe: 1 Anfang j=1: Feld A[0..j-1] enthält nur ein Element A[0], ist sortiert 2 aktuelles Element mit Wert key, die Werte A[j-1], A[j-2],... werden jeweils eine Position nach rechts verschoben, bis korrekte Position A[i] gefunden für aktuelles Element, Element wird dort eingefügt Feld A[0..j-1] sortiert 3 Algorithmus terminiert wenn j==n, also gilt mit voriger Invariante P: A[0..n-1] ist sortiert 35

66 Zusammenfassung 1 Einführung 2 Mathematische Grundlagen 3 Elementare Datenstrukturen 4 Grundlagen der Korrektheit von Algorithmen Motivation und Spezifikation Verifikation Beispiel: Insertion Sort 36

Programm heute. Algorithmen und Datenstrukturen (für ET/IT) Beispiele für Fehler II. Sommersemester Dr. Stefanie Demirci

Programm heute. Algorithmen und Datenstrukturen (für ET/IT) Beispiele für Fehler II. Sommersemester Dr. Stefanie Demirci Programm heute Algorithmen und Datenstrukturen (für ET/IT) Sommersemester 017 Dr. Stefanie Demirci Computer Aided Medical Procedures Technische Universität München 1 Einführung Grundlagen von Algorithmen

Mehr

Algorithmen und Datenstrukturen (für ET/IT)

Algorithmen und Datenstrukturen (für ET/IT) Algorithmen und Datenstrukturen (für ET/IT) Sommersemester 2014 Dr. Tobias Lasser Computer Aided Medical Procedures Technische Universität München 2 Programm heute 1 Einführung 2 Grundlagen von Algorithmen

Mehr

Algorithmen und Datenstrukturen (für ET/IT)

Algorithmen und Datenstrukturen (für ET/IT) Algorithmen und Datenstrukturen (für ET/IT) Sommersemester 2017 Dr. Stefanie Demirci Computer Aided Medical Procedures Technische Universität München Wiederholung Fr ein Projekt soll ein Embedded Controller

Mehr

Wiederholung: Zusammenfassung Felder. Algorithmen und Datenstrukturen (für ET/IT) Definition Abstrakter Datentyp. Programm heute

Wiederholung: Zusammenfassung Felder. Algorithmen und Datenstrukturen (für ET/IT) Definition Abstrakter Datentyp. Programm heute Wiederholung: Zusammenfassung Felder Algorithmen und Datenstrukturen (für ET/IT) Wintersemester / Dr. Tobias Lasser Computer Aided Medical Procedures Technische Universität München Ein Feld A kann repräsentiert

Mehr

Programm heute. Algorithmen und Datenstrukturen (für ET/IT) Definition Algorithmus. Wie beschreibt man Algorithmen?

Programm heute. Algorithmen und Datenstrukturen (für ET/IT) Definition Algorithmus. Wie beschreibt man Algorithmen? Programm heute Algorithmen und Datenstrukturen (für ET/IT) Sommersemester 2015 1 Einführung Dr. Tobias Lasser Computer Aided Medical Procedures Technische Universität München 2 Grundlagen von Algorithmen

Mehr

Algorithmen und Datenstrukturen (für ET/IT)

Algorithmen und Datenstrukturen (für ET/IT) Algorithmen und Datenstrukturen (für ET/IT) Sommersemester 2016 Dr. Tobias Lasser Computer Aided Medical Procedures Technische Universität München Programm heute 1 Einführung 2 Grundlagen von Algorithmen

Mehr

Algorithmen und Datenstrukturen (für ET/IT)

Algorithmen und Datenstrukturen (für ET/IT) Algorithmen und Datenstrukturen (für ET/IT) Sommersemester 2016 Dr. Tobias Lasser Computer Aided Medical Procedures Technische Universität München Programm heute 1 Einführung 2 Grundlagen von Algorithmen

Mehr

Organisatorisches. Algorithmen und Datenstrukturen (für ET/IT) Programm heute. Definition Feld. Definition Feld

Organisatorisches. Algorithmen und Datenstrukturen (für ET/IT) Programm heute. Definition Feld. Definition Feld Organisatorisches Algorithmen und Datenstrukturen (für ET/IT) Sommersemester 208 Dr. Stefanie Demirci Computer Aided Medical Procedures Technische Universität München TUMonline-Einträge: Vorlesung https://campus.tum.de/tumonline/wblv.

Mehr

Programm heute. Algorithmen und Datenstrukturen (für ET/IT) Feld als sequentielle Liste. Definition Feld

Programm heute. Algorithmen und Datenstrukturen (für ET/IT) Feld als sequentielle Liste. Definition Feld Programm heute Algorithmen und Datenstrukturen (für ET/IT) Sommersemester 205 Dr. Tobias Lasser Computer Aided Medical Procedures Technische Universität München Einführung 2 Grundlagen von Algorithmen

Mehr

Programm heute. Algorithmen und Datenstrukturen (für ET/IT) Fehlerarten. Validation. Wintersemester 2012/13. Dr. Tobias Lasser

Programm heute. Algorithmen und Datenstrukturen (für ET/IT) Fehlerarten. Validation. Wintersemester 2012/13. Dr. Tobias Lasser Programm heute Algorithmen und Datenstrukturen (für ET/IT) Wintersemester 01/13 Dr. Tobias Lasser Computer Aided Medical Procedures Technische Universität München 1 Einführung Mathematische Grundlagen

Mehr

Algorithmen und Datenstrukturen (für ET/IT)

Algorithmen und Datenstrukturen (für ET/IT) Algorithmen und Datenstrukturen (für ET/IT) Sommersemester 2014 Dr. Tobias Lasser Computer Aided Medical Procedures Technische Universität München 2 Programm heute 1 Einführung 2 Grundlagen von Algorithmen

Mehr

Algorithmen und Datenstrukturen (für ET/IT)

Algorithmen und Datenstrukturen (für ET/IT) Algorithmen und Datenstrukturen (für ET/IT) Sommersemester 2014 Dr. Tobias Lasser Computer Aided Medical Procedures Technische Universität München 2 Programm heute 1 Einführung 2 Grundlagen von Algorithmen

Mehr

Technische Universität München SoSe 2018 Fakultät für Informatik, I Mai 2018 Dr. Stefanie Demirci

Technische Universität München SoSe 2018 Fakultät für Informatik, I Mai 2018 Dr. Stefanie Demirci Name: Vorname: Matr. Nr.: Technische Universität München SoSe 2018 Fakultät für Informatik, I-16 9. Mai 2018 Dr. Stefanie Demirci Probeklausur zu Algorithmen und Datenstrukturen Allgemeine Hinweise Die

Mehr

Programm heute. Algorithmen und Datenstrukturen (für ET/IT) Definition Feld. Feld als sequentielle Liste

Programm heute. Algorithmen und Datenstrukturen (für ET/IT) Definition Feld. Feld als sequentielle Liste Programm heute Algorithmen und Datenstrukturen (für ET/IT) Sommersemester 204 Dr. Tobias Lasser Computer Aided Medical Procedures Technische Universität München Einführung 2 Grundlagen von Algorithmen

Mehr

Counting - Sort [ [ ] [ [ ] 1. SS 2008 Datenstrukturen und Algorithmen Sortieren in linearer Zeit

Counting - Sort [ [ ] [ [ ] 1. SS 2008 Datenstrukturen und Algorithmen Sortieren in linearer Zeit Counting-Sort Counting - Sort ( A,B,k ). for i to k. do C[ i]. for j to length[ A]. do C[ A[ j ] C[ A[ j ] +. > C[ i] enthält Anzahl der Elemente in 6. for i to k. do C[ i] C[ i] + C[ i ]. > C[ i] enthält

Mehr

Technische Universität München SoSe 2015 Institut für Informatik I Mai 2015 Dr. Tobias Lasser. Aufgabe 1 Rechnen mit Landau-Symbolen

Technische Universität München SoSe 2015 Institut für Informatik I Mai 2015 Dr. Tobias Lasser. Aufgabe 1 Rechnen mit Landau-Symbolen Technische Universität München SoSe 2015 Institut für Informatik I-16 27. Mai 2015 Dr. Tobias Lasser Lösungsvorschläge zur Musterklausur zu Algorithmen und Datenstrukturen Aufgabe 1 Rechnen mit Landau-Symbolen

Mehr

Organisatorisches. Algorithmen und Datenstrukturen (für ET/IT) Programm heute. Tutorübungen

Organisatorisches. Algorithmen und Datenstrukturen (für ET/IT) Programm heute. Tutorübungen Organisatorisches Algorithmen und Datenstrukturen (für ET/IT) Sommersemester 2018 Dr. Stefanie Demirci Computer Aided Medical Procedures Technische Universität München Vorlesung online: Webseite: http://campar.in.tum.de/chair/teachingss18aud

Mehr

Algorithmen und Datenstrukturen (für ET/IT)

Algorithmen und Datenstrukturen (für ET/IT) Algorithmen und Datenstrukturen (für ET/IT) Sommersemester 2017 Dr. Stefanie Demirci Computer Aided Medical Procedures Technische Universität München Programm heute 1 Einführung 2 Grundlagen von Algorithmen

Mehr

Algorithmen und Datenstrukturen (für ET/IT)

Algorithmen und Datenstrukturen (für ET/IT) Algorithmen und Datenstrukturen (für ET/IT) Sommersemester 2018 Dr. Stefanie Demirci Computer Aided Medical Procedures Technische Universität München Organisatorisches: Keine Vorlesung nächste Woche wegen

Mehr

Übung zu Algorithmen und Datenstrukturen (für ET/IT)

Übung zu Algorithmen und Datenstrukturen (für ET/IT) Übung zu Algorithmen und Datenstrukturen (für ET/IT) Sommersemester 2015 Matthias Wieczorek Computer-Aided Medical Procedures Technische Universität München Administratives Zentralübung (Mittwoch, 09:45

Mehr

Übung zu Algorithmen und Datenstrukturen (für ET/IT)

Übung zu Algorithmen und Datenstrukturen (für ET/IT) Übung zu Algorithmen und Datenstrukturen (für ET/IT) Sommersemester 2017 Rüdiger Göbl, Mai Bui Computer Aided Medical Procedures Technische Universität München Administratives Zentralübung (Mittwoch, 09:45

Mehr

Was bisher geschah Modellierung von Daten durch Mengen Beziehungen (Zusammenhänge und Eigenschaften) durch Relationen, Graphen und Funktionen

Was bisher geschah Modellierung von Daten durch Mengen Beziehungen (Zusammenhänge und Eigenschaften) durch Relationen, Graphen und Funktionen Was bisher geschah Modellierung von Daten durch Mengen Beziehungen (Zusammenhänge und Eigenschaften) durch Relationen, Graphen und Funktionen Anforderungen durch Logiken Modellierung zusammenhängender

Mehr

Übung Algorithmen und Datenstrukturen

Übung Algorithmen und Datenstrukturen Übung Algorithmen und Datenstrukturen Sommersemester 2017 Marc Bux, Humboldt-Universität zu Berlin Agenda 1. (Sortierte) Listen 2. Stacks & Queues 3. Datenstrukturen 4. Rekursion und vollständige Induktion

Mehr

{P} S {Q} {P} S {Q} {P} S {Q} Inhalt. Hoare-Kalkül. Hoare-Kalkül. Hoare-Tripel. Hoare-Tripel. Hoare-Tripel

{P} S {Q} {P} S {Q} {P} S {Q} Inhalt. Hoare-Kalkül. Hoare-Kalkül. Hoare-Tripel. Hoare-Tripel. Hoare-Tripel Inhalt Hoare-Kalkül Formale Verifizierung Hoare-Kalkül while-sprache Terminierung Partielle / totale Korrektheit 4.0 Hoare-Kalkül entwickelt von C.A.R. (Tony) Hoare (britischer Informatiker), 1969 formales

Mehr

Algorithmen und Datenstrukturen (für ET/IT) Wiederholung: Ziele der Vorlesung. Wintersemester 2012/13. Dr. Tobias Lasser

Algorithmen und Datenstrukturen (für ET/IT) Wiederholung: Ziele der Vorlesung. Wintersemester 2012/13. Dr. Tobias Lasser Algorithmen und Datenstrukturen (für ET/IT) Wintersemester 2012/13 Dr. Tobias Lasser Computer Aided Medical Procedures Technische Universität München Wiederholung: Ziele der Vorlesung Wissen: Algorithmische

Mehr

Algorithmen und Datenstrukturen (für ET/IT)

Algorithmen und Datenstrukturen (für ET/IT) Algorithmen und Datenstrukturen (für ET/IT) Wintersemester 2012/13 Dr. Tobias Lasser Computer Aided Medical Procedures Technische Universität München Wiederholung: Ziele der Vorlesung Wissen: Algorithmische

Mehr

Algorithmen und Datenstrukturen

Algorithmen und Datenstrukturen Algorithmen und Datenstrukturen Wintersemester 2013/14 1. Vorlesung Kapitel 1: Sortieren Prof. Dr. Alexander Wolff Lehrstuhl für Informatik I Das Problem Eingabe Gegeben: eine Folge A = a 1, a 2,..., a

Mehr

Korrektheit imperativer Algorithmen

Korrektheit imperativer Algorithmen LUDWIG- MAXIMILIANS- UNIVERSITY MUNICH DEPARTMENT INSTITUTE FOR INFORMATICS DATABASE Abschnitt 9 Korrektheit imperativer Algorithmen Skript zur Vorlesung Einführung in die Programmierung im Wintersemester

Mehr

Algorithmen und Datenstrukturen

Algorithmen und Datenstrukturen Algorithmen und Datenstrukturen Wintersemester 2012/13 1. Vorlesung Kapitel 1: Sortieren Prof. Dr. Alexander Wolff Lehrstuhl für Informatik I Das Problem Eingabe Gegeben: eine Folge A = a 1, a 2,..., a

Mehr

WS 05/06 mod Verifikation

WS 05/06 mod Verifikation 3.3 Verifikation WS 05/06 mod 351 Verifikation ist der Beweis der Korrektheit eines Algorithmus relativ zu seiner Spezifikation. Die Aussagen gelten für alle Ausführungen des Algorithmus. Sie werden statisch

Mehr

Einführung in die Programmiertechnik

Einführung in die Programmiertechnik Einführung in die Programmiertechnik Verifikation 2 Vermeidung von Fehlern Verwendung geeigneter Werkzeuge Auswahl einer dem Problem angemessenen Programmiersprache Verwendung eines zuverlässigen Compilers

Mehr

13. Dynamische Datenstrukturen

13. Dynamische Datenstrukturen Motivation: Stapel. Dynamische Datenstrukturen Verkettete Listen, Abstrakte Datentypen Stapel, Warteschlange, Sortierte Liste 40 40 Motivation: Stapel ( push, pop, top, empty ) Wir brauchen einen neuen

Mehr

11. Elementare Datenstrukturen

11. Elementare Datenstrukturen 11. Elementare Datenstrukturen Definition 11.1: Eine dynamische Menge ist gegeben durch eine oder mehrer Mengen von Objekten sowie Operationen auf diesen Mengen und den Objekten der Mengen. Dynamische

Mehr

Kapitel 4. Kontrollstrukturen

Kapitel 4. Kontrollstrukturen Kapitel 4 Kontrollstrukturen Kontrollstrukturen 1 Ziele Kontrollstrukturen in imperativen Programmen kennenlernen und verstehen. Realisierung der Kontrollstrukturen in Java. Kontrollstrukturen 2 Anweisungen

Mehr

16. Dynamische Datenstrukturen

16. Dynamische Datenstrukturen Datenstrukturen 6. Dynamische Datenstrukturen Eine Datenstruktur organisiert Daten so in einem Computer, dass man sie effizient nutzen kann. Verkettete Listen, Abstrakte Datentypen Stapel, Warteschlange

Mehr

Übung zu Algorithmen und Datenstrukturen (für ET/IT)

Übung zu Algorithmen und Datenstrukturen (für ET/IT) Übung zu Algorithmen und Datenstrukturen (für ET/IT) Sommersemester 2018 Mai Bui Computer Aided Medical Procedures Technische Universität München Administratives Zentralübung (Mittwoch, 09:45 11:15) Programmierbeispiele

Mehr

Kapitel 4. Kontrollstrukturen

Kapitel 4. Kontrollstrukturen Kapitel 4 Kontrollstrukturen Kontrollstrukturen 1 Ziele Kontrollstrukturen in imperativen Programmen kennenlernen und verstehen. Realisierung der Kontrollstrukturen in Java. Kontrollstrukturen 2 Anweisungen

Mehr

Informatik II, SS 2014

Informatik II, SS 2014 Informatik II SS 2014 (Algorithmen & Datenstrukturen) Vorlesung 7 (21.5.2014) Binäre Suche, Hashtabellen I Algorithmen und Komplexität Abstrakte Datentypen : Dictionary Dictionary: (auch: Maps, assoziative

Mehr

8 Elementare Datenstrukturen

8 Elementare Datenstrukturen Algorithmen und Datenstrukturen 186 8 Elementare Datenstrukturen In diesem und dem folgenden Kapitel werden grundlegende Techniken der Darstellung und Manipulation dynamischer Mengen auf Computern vorgestellt.

Mehr

C. A. R. Hoare. An Axiomatic Basis for Computer Programming. Nicolas Schelp. Proseminar Assertions SS 2007

C. A. R. Hoare. An Axiomatic Basis for Computer Programming. Nicolas Schelp. Proseminar Assertions SS 2007 C. A. R. Hoare An Axiomatic Basis for Computer Programming Nicolas Schelp Proseminar Assertions SS 2007 Inhalt Motivation Kurze Biographie Der Hoare-Kalkül Axiome und Inferenzregeln des Hoare-Kalküls Die

Mehr

Algorithmen als systematische Vorgehensweisen zur Lösung eines formal definierten Problems

Algorithmen als systematische Vorgehensweisen zur Lösung eines formal definierten Problems 4. Algorithmen Motivation Algorithmen als systematische Vorgehensweisen zur Lösung eines formal definierten Problems Der Begriff Algorithmus geht auf den Gelehrten Muhammad al-chwarizmi zurück, der um

Mehr

Algorithmen als systematische Vorgehensweisen zur Lösung eines formal definierten Problems

Algorithmen als systematische Vorgehensweisen zur Lösung eines formal definierten Problems 4. Algorithmen Motivation Algorithmen als systematische Vorgehensweisen zur Lösung eines formal definierten Problems Der Begriff Algorithmus geht auf den Gelehrten Muhammad al-chwarizmi zurück, der um

Mehr

Problem: Gegeben Spezifikation (P,Q) und Implementierung S Gesucht formaler (automatisierbarer?) Beweis, dass S (P,Q) erfüllt.

Problem: Gegeben Spezifikation (P,Q) und Implementierung S Gesucht formaler (automatisierbarer?) Beweis, dass S (P,Q) erfüllt. Formale Verifikation von Algorithmen 1.3 Verifikation Problem: Gegeben Spezifikation (P,Q) und Implementierung S Gesucht formaler (automatisierbarer?) Beweis, dass S (P,Q) erfüllt. Bisher nicht möglich

Mehr

Algorithmen und Datenstrukturen (für ET/IT) Programm heute. Wintersemester 2012/13. Dr. Tobias Lasser. 1 Organisation

Algorithmen und Datenstrukturen (für ET/IT) Programm heute. Wintersemester 2012/13. Dr. Tobias Lasser. 1 Organisation Algorithmen und Datenstrukturen (für ET/IT) Wintersemester 2012/13 Dr. Tobias Lasser Computer Aided Medical Procedures Technische Universität München Programm heute 1 Organisation 2 Einführung Ziele und

Mehr

Algorithmen und Programmieren II Programmverifikation {V} P {N}

Algorithmen und Programmieren II Programmverifikation {V} P {N} Algorithmen und Programmieren II Programmverifikation {V} P {N} SS 2012 Prof. Dr. Margarita Esponda ALP II: Margarita Esponda, 11. Vorlesung, 22.5.2012 1 Assertions oder Zusicherungen Das Konzept der Zusicherungen

Mehr

Informatik I - Programmierung Globalübung Hoare-Kalkül. Thomas Weiler. Fachgruppe Informatik RWTH Aachen. T. Weiler, RWTH Aachen - 1 -

Informatik I - Programmierung Globalübung Hoare-Kalkül. Thomas Weiler. Fachgruppe Informatik RWTH Aachen. T. Weiler, RWTH Aachen - 1 - Informatik I - Programmierung Globalübung 11.11.2003 Hoare-Kalkül Thomas Weiler Fachgruppe Informatik RWTH Aachen T. Weiler, RWTH Aachen - 1 - Ariane 5 Die Ariane 5 ist das jüngste Modell der Trägerrakete

Mehr

Algorithmen und Datenstrukturen (für ET/IT)

Algorithmen und Datenstrukturen (für ET/IT) Algorithmen und Datenstrukturen (für ET/IT) Wintersemester 2012/13 Dr. Tobias Lasser Computer Aided Medical Procedures Technische Universität München Programm heute 1 Organisation 2 Einführung Ziele und

Mehr

Übung Algorithmen und Datenstrukturen

Übung Algorithmen und Datenstrukturen Übung Algorithmen und Datenstrukturen Sommersemester 2017 Patrick Schäfer, Humboldt-Universität zu Berlin Agenda 1. Sortierte Listen 2. Stacks & Queues 3. Teile und Herrsche Nächste Woche: Vorrechnen (first-come-first-served)

Mehr

Kapitel 4: Formale Verifikation

Kapitel 4: Formale Verifikation Kapitel 4: Formale Verifikation Inhalt 4.1 Grundlagen 4.2 Verifikation auf axiomatischer Basis 4.3 Verifikation einzelner Eigenschaften 4.4 Stärken und Schwächen formaler Verifikation Schlüsselbegriffe

Mehr

n 1. Erste Schritte n 2. Einfache Datentypen n 3. Anweisungen und Kontrollstrukturen n 4. Verifikation n 5. Reihungen (Arrays)

n 1. Erste Schritte n 2. Einfache Datentypen n 3. Anweisungen und Kontrollstrukturen n 4. Verifikation n 5. Reihungen (Arrays) n 1. Erste Schritte n 2. Einfache Datentypen n 3. Anweisungen und Kontrollstrukturen n 4. Verifikation n 5. Reihungen (Arrays) II.1.4. Verifikation - 1 - 4. Verifikation n Spezifikation: Angabe, was ein

Mehr

Das diesem Dokument zugrundeliegende Vorhaben wurde mit Mitteln des Bundesministeriums für Bildung und Forschung unter dem Förderkennzeichen

Das diesem Dokument zugrundeliegende Vorhaben wurde mit Mitteln des Bundesministeriums für Bildung und Forschung unter dem Förderkennzeichen Das diesem Dokument zugrundeliegende Vorhaben wurde mit Mitteln des Bundesministeriums für Bildung und Forschung unter dem Förderkennzeichen 16OH21005 gefördert. Die Verantwortung für den Inhalt dieser

Mehr

Algorithmen und Datenstrukturen (für ET/IT) Probeklausur. Sommersemester Dr. Stefanie Demirci

Algorithmen und Datenstrukturen (für ET/IT) Probeklausur. Sommersemester Dr. Stefanie Demirci Algorithmen und Datenstrukturen (für ET/IT) Sommersemester 2017 Dr. Stefanie Demirci Computer Aided Medical Procedures Technische Universität München Probeklausur Wann? während Zentralübung am Mittwoch,

Mehr

4.3 Verifikation von Aussagen über Algorithmen

4.3 Verifikation von Aussagen über Algorithmen 4.3 Verifikation von Aussagen über Algorithmen Hoaresche Logik: Kalkül zum Beweisen von Aussagen über Algorithmen und Programme, Programm-Verifikation, [C.A.R. Hoare, 1969]. Mod - 4.51 Statische Aussagen

Mehr

Kapitel 3 Zur Korrektheit und Effizienz von Algorithmen

Kapitel 3 Zur Korrektheit und Effizienz von Algorithmen Kapitel 3 Zur Korrektheit und Effizienz von Algorithmen Ziel: Kurze Einführung in den Pseudocode zur Beschreibung von Algorithmen Induktionsbeweise als wichtiges Hilfsmittel, um die Korrektheit eines Algorithmus

Mehr

Kapitel 4: Anweisungen und Kontrollstrukturen

Kapitel 4: Anweisungen und Kontrollstrukturen inführung in die Informatik: Programmierung und Softwareentwicklung Wintersemester 2018/19 Kapitel 4: Anweisungen und Kontrollstrukturen Prof. Dr. David Sabel Lehr- und Forschungseinheit für Theoretische

Mehr

Probeklausur. Algorithmen und Datenstrukturen (für ET/IT) Kapitel 1: Einführung. Programm heute. Wann? während Zentralübung am Mittwoch, 21.

Probeklausur. Algorithmen und Datenstrukturen (für ET/IT) Kapitel 1: Einführung. Programm heute. Wann? während Zentralübung am Mittwoch, 21. Probeklausur Algorithmen und strukturen (für ET/IT) Sommersemester 2014 Dr. Tobias Lasser Computer Aided Medical Procedures Technische Universität München Wann? während Zentralübung am Mittwoch, 21. Mai

Mehr

5. Algorithmen. K. Bothe, Institut für Informatik, HU Berlin, GdP, WS 2015/16

5. Algorithmen. K. Bothe, Institut für Informatik, HU Berlin, GdP, WS 2015/16 5. Algorithmen K. Bothe, Institut für Informatik, HU Berlin, GdP, WS 2015/16 Version: 21. Okt. 2015 1. Berechne 2 n. Zu lösende Probleme 2. Berechne die Fakultät einer nat. Zahl: n! = 1 * 2 *... n 3. Entscheide,

Mehr

Abschnitt 11: Korrektheit von imperativen Programmen

Abschnitt 11: Korrektheit von imperativen Programmen Abschnitt 11: Korrektheit von imperativen Programmen 11. Korrektheit von imperativen Programmen 11.1 11.2Testen der Korrektheit in Java Peer Kröger (LMU München) in die Programmierung WS 16/17 931 / 961

Mehr

Algorithmen und Datenstrukturen (für ET/IT)

Algorithmen und Datenstrukturen (für ET/IT) Algorithmen und Datenstrukturen (für ET/IT) Wintersemester 2012/13 Dr. Tobias Lasser Computer Aided Medical Procedures Technische Universität München Feedback Vielen Dank für das Feedback auf Moodle! Bitte

Mehr

! 1. Erste Schritte! 2. Einfache Datentypen! 3. Anweisungen und Kontrollstrukturen! 4. Verifikation! 5. Reihungen (Arrays) II.1.4. Verifikation - 1 -

! 1. Erste Schritte! 2. Einfache Datentypen! 3. Anweisungen und Kontrollstrukturen! 4. Verifikation! 5. Reihungen (Arrays) II.1.4. Verifikation - 1 - ! 1. Erste Schritte! 2. Einfache Datentypen! 3. Anweisungen und Kontrollstrukturen! 4. Verifikation! 5. Reihungen (Arrays) II.1.4. Verifikation - 1 - 4. Verifikation! Spezifikation: Angabe, was ein Programm

Mehr

Formale Systeme Logik: Verifikation von Aussagen über Algorithmen. Ana Sokolova statt Robert Elsässer

Formale Systeme Logik: Verifikation von Aussagen über Algorithmen. Ana Sokolova statt Robert Elsässer Formale Systeme Logik: Verifikation von Aussagen über Algorithmen 20.12.2012 Ana Sokolova statt Robert Elsässer Verifikation von Aussagen über Algorithmen Hoaresche Logik: Kalkül zum Beweisen von Aussagen

Mehr

Operatoren für elementare Datentypen Bedingte Anweisungen Schleifen. Operatoren für elementare Datentypen Bedingte Anweisungen Schleifen

Operatoren für elementare Datentypen Bedingte Anweisungen Schleifen. Operatoren für elementare Datentypen Bedingte Anweisungen Schleifen Programmieren I Martin Schultheiß Hochschule Darmstadt Wintersemester 2011/2012 1 / 25 Operatoren für elementare Datentypen Bedingte Schleifen 2 / 25 Zuweisungsoperator Die Zuweisung von Werten an Variablen

Mehr

12. Dynamische Datenstrukturen

12. Dynamische Datenstrukturen Motivation: Stapel. Dynamische Datenstrukturen Verkettete Listen, Abstrakte Datentypen Stapel, Warteschlange, Implementationsvarianten der verketteten Liste 0 04 Motivation: Stapel ( push, pop, top, empty

Mehr

Algorithmen und Datenstrukturen 1-3. Seminar -

Algorithmen und Datenstrukturen 1-3. Seminar - Algorithmen und Datenstrukturen 1-3. Seminar - Dominic Rose Bioinformatics Group, University of Leipzig Wintersemester 2009/10 Outline Spezielle Listen: Stacks, Queues Sortierverfahren 3. Übungsserie Wiederholung:

Mehr

5.3 Korrektheit und Verifikation

5.3 Korrektheit und Verifikation 5.3 Korrektheit und Verifikation Korrektheit bedeutet, dass ein Algorithmus oder ein Programm das in der Spezifikation beschriebene Problem für beliebige Eingabedaten korrekt löst. Die Korrektheit kann

Mehr

Algorithmen I. Tutorium 1-3. Sitzung. Dennis Felsing

Algorithmen I. Tutorium 1-3. Sitzung. Dennis Felsing Algorithmen I Tutorium 1-3. Sitzung Dennis Felsing dennis.felsing@student.kit.edu www.stud.uni-karlsruhe.de/~ubcqr/algo 2011-05-02 Überblick 1 Sortieren und Suchen 2 Mastertheorem 3 Datenstrukturen 4 Kreativaufgabe

Mehr

Korrektheit und Hoare-Kalkül für Imperative Programme

Korrektheit und Hoare-Kalkül für Imperative Programme Korrektheit und Hoare-Kalkül für Imperative Programme Martin Wirsing in Zusammenarbeit mit Moritz Hammer und Axel Rauschmayer SS 06 Ziele Partielle und totale Korrektheit kennen lernen Die Regeln des Hoare-Kalkül

Mehr

1. Erste Schritte 2. Einfache Datentypen 3. Anweisungen und Kontrollstrukturen 4. Verifikation 5. Reihungen (Arrays) II.1.4. Verifikation - 1 -

1. Erste Schritte 2. Einfache Datentypen 3. Anweisungen und Kontrollstrukturen 4. Verifikation 5. Reihungen (Arrays) II.1.4. Verifikation - 1 - 1. Erste Schritte 2. Einfache Datentypen 3. Anweisungen und Kontrollstrukturen 4. Verifikation 5. Reihungen (Arrays) II.1.4. Verifikation - 1 - 4. Verifikation Spezifikation: Angabe, was ein Programm tun

Mehr

Algorithmen und Datenstrukturen

Algorithmen und Datenstrukturen Algorithmen und Datenstrukturen Dipl. Inform. Andreas Wilkens aw@awilkens.com Überblick Grundlagen Definitionen Eigene Entwicklungen Datenstrukturen Elementare Datentypen Abstrakte Datentypen Elementare

Mehr

2. Grundlagen. Beschreibung von Algorithmen durch Pseudocode. Korrektheit von Algorithmen durch Invarianten.

2. Grundlagen. Beschreibung von Algorithmen durch Pseudocode. Korrektheit von Algorithmen durch Invarianten. 2. Grundlagen Beschreibung von Algorithmen durch Pseudocode. Korrektheit von Algorithmen durch Invarianten. Laufzeitverhalten beschreiben durch O-Notation. 1 Beispiel Minimum-Suche Eingabe bei Minimum

Mehr

Algorithmen und Datenstrukturen (für ET/IT)

Algorithmen und Datenstrukturen (für ET/IT) Algorithmen und Datenstrukturen (für ET/IT) Wintersemester 2012/13 Dr. Tobias Lasser Computer Aided Medical Procedures Technische Universität München Programm 1 Organisation 2 Einführung Ziele und Inhalt

Mehr

Algorithmen und Datenstrukturen (fu r ET/IT) Personen. Programm heute. Wintersemester 2012/13. Wintersemester 2012/13. Dr.

Algorithmen und Datenstrukturen (fu r ET/IT) Personen. Programm heute. Wintersemester 2012/13. Wintersemester 2012/13. Dr. Algorithmen und Datenstrukturen (fu r ET/IT) Algorithmen und Datenstrukturen (fu r ET/IT) Wintersemester 2012/13 Wintersemester 2012/13 Dr. Tobias Lasser Dr. Tobias Lasser Computer Aided Medical Procedures

Mehr

5.3 Korrektheit und Verifikation

5.3 Korrektheit und Verifikation 5.3 Korrektheit und Verifikation Korrektheit bedeutet, dass ein Algorithmus oder ein Programm das in der Spezifikation beschriebene Problem für beliebige Eingabedaten korrekt löst. Die Korrektheit kann

Mehr

Algorithmen und Datenstrukturen (für ET/IT)

Algorithmen und Datenstrukturen (für ET/IT) Algorithmen und Datenstrukturen (für ET/IT) Sommersemester 2015 Dr. Tobias Lasser Computer Aided Medical Procedures Technische Universität München Programm heute 1 Einführung 2 Grundlagen von Algorithmen

Mehr

Kapitel 5: Abstrakte Algorithmen und Sprachkonzepte. Elementare Schritte

Kapitel 5: Abstrakte Algorithmen und Sprachkonzepte. Elementare Schritte Elementare Schritte Ein elementarer Berechnungsschritt eines Algorithmus ändert im Allgemeinen den Wert von Variablen Zuweisungsoperation von fundamentaler Bedeutung Zuweisungsoperator In Pascal := In

Mehr

Verifikation von Programmen

Verifikation von Programmen http://scam-trap.com/i/stophacking1.gif Verifikation von Programmen OOPM, Ralf Lämmel 380 Was tun? (Mit den Spezifikationen) Dokumentation Überprüfen der Bedingungen zur Laufzeit Verifizieren der Bedingungen

Mehr

1. Erste Schritte 2. Einfache Datentypen 3. Anweisungen und Kontrollstrukturen 4. Verifikation 5. Reihungen (Arrays) II.1.4. Verifikation - 1 -

1. Erste Schritte 2. Einfache Datentypen 3. Anweisungen und Kontrollstrukturen 4. Verifikation 5. Reihungen (Arrays) II.1.4. Verifikation - 1 - 1. Erste Schritte 2. Einfache Datentypen 3. Anweisungen und Kontrollstrukturen 4. Verifikation 5. Reihungen (Arrays) II.1.4. Verifikation - 1 - 4. Verifikation Spezifikation: Angabe, was ein Programm tun

Mehr

Algorithmen und Datenstrukturen (für ET/IT)

Algorithmen und Datenstrukturen (für ET/IT) Algorithmen und Datenstrukturen (für ET/IT) Wintersemester 2012/13 Dr. Tobias Lasser Computer Aided Medical Procedures Technische Universität München Programm heute 1 Einführung 2 Mathematische Grundlagen

Mehr

Martin Unold INFORMATIK. Geoinformatik und Vermessung

Martin Unold INFORMATIK. Geoinformatik und Vermessung Wiederholung So sieht ein leeres Java-Programm aus public class Programmname { public static void main (String[] args) { // Hier stehen die Anweisungen Anweisungen mit Variablen Wiederholung Deklaration

Mehr

Einstieg in die Informatik mit Java

Einstieg in die Informatik mit Java 1 / 41 Einstieg in die Informatik mit Java Weitere Anweisungen Gerd Bohlender Institut für Angewandte und Numerische Mathematik Gliederung 2 / 41 1 Überblick 2 Verbundanweisung 3 Bedingte Anweisung 4 Auswahlanweisung

Mehr

Datenstrukturen & Algorithmen

Datenstrukturen & Algorithmen Datenstrukturen & Algorithmen VO 708.031 Um was geht es? Datenstrukturen Algorithmen Algorithmus Versuch einer Erklärung: Ein Algorithmus nimmt bestimmte Daten als Input und transformiert diese nach festen

Mehr

Algorithmen & Komplexität

Algorithmen & Komplexität Algorithmen & Komplexität Angelika Steger Institut für Theoretische Informatik steger@inf.ethz.ch Breitensuche, Tiefensuche Wir besprechen nun zwei grundlegende Verfahren, alle Knoten eines Graphen zu

Mehr

Algorithmen und Datenstrukturen

Algorithmen und Datenstrukturen Universität Innsbruck Institut für Informatik Zweite Prüfung 16. Oktober 2008 Algorithmen und Datenstrukturen Name: Matrikelnr: Die Prüfung besteht aus 8 Aufgaben. Die verfügbaren Punkte für jede Aufgabe

Mehr

Einführung in die Programmierung

Einführung in die Programmierung Skript zur Vorlesung: Einführung in die Programmierung WiSe 2009 / 2010 Skript 2009 Christian Böhm, Peer Kröger, Arthur Zimek Prof. Dr. Christian Böhm Annahita Oswald Bianca Wackersreuther Ludwig-Maximilians-Universität

Mehr

Beispiel 1 zur Verifikation eines bedingten Anweisung. Hoare-Regel für die bedingte Anweisung. else

Beispiel 1 zur Verifikation eines bedingten Anweisung. Hoare-Regel für die bedingte Anweisung. else Hoare-Regel für die bedingte Anweisung I1 : I2 : {B P } S 1 {Q} { nicht B P } {Q} {P } if (B) then S 1 {Q} {B P } S 1 {Q} { nicht B P } S 2 {Q} {P } if (B) then S 1 else S 2 {Q} In der Regel für bedingte

Mehr

Learning Object-Oriented Programming. Algorithmen. Algorithmusbegriff. Klärung der Herkunft des Begriffs Formale Definition von Algorithmus

Learning Object-Oriented Programming. Algorithmen. Algorithmusbegriff. Klärung der Herkunft des Begriffs Formale Definition von Algorithmus Algorithmen Algorithmusbegriff Klärung der Herkunft des Begriffs Formale Definition von Algorithmus Algorithmusbegriff Algorithmen sind eine der ältesten (abstrakten) Beschreibungstechniken für Abläufe.

Mehr

Brückenkurs Programmieren

Brückenkurs Programmieren Brückenkurs Programmieren Verzweigungen, Operatoren, Schleifen, Arrays Christopher Schölzel Technische Hochschule Mittelhessen 01.10.2013 Christopher Schölzel (THM) Brückenkurs Programmieren 01.10.2013

Mehr

Beispiellösung zu den Übungen Datenstrukturen und Algorithmen SS 2008 Blatt 5

Beispiellösung zu den Übungen Datenstrukturen und Algorithmen SS 2008 Blatt 5 Robert Elsässer Paderborn, den 15. Mai 2008 u.v.a. Beispiellösung zu den Übungen Datenstrukturen und Algorithmen SS 2008 Blatt 5 AUFGABE 1 (6 Punkte): Nehmen wir an, Anfang bezeichne in einer normalen

Mehr

1 Bedingte Anweisungen. 2 Vergleiche und logische Operatoren. 3 Fallunterscheidungen. 4 Zeichen und Zeichenketten. 5 Schleifen.

1 Bedingte Anweisungen. 2 Vergleiche und logische Operatoren. 3 Fallunterscheidungen. 4 Zeichen und Zeichenketten. 5 Schleifen. Themen der Übung Kontrollstrukturen, Pseudocode und Modulo-Rechnung CoMa-Übung III TU Berlin 9.10.01 1 Bedingte Anweisungen Vergleiche und logische Operatoren 3 Fallunterscheidungen 4 Zeichen und Zeichenketten

Mehr

Kurs 1612 Konzepte imperativer Programmierung Musterlösung zur Nachklausur am

Kurs 1612 Konzepte imperativer Programmierung Musterlösung zur Nachklausur am 1 Aufgabe 1 a) Da Effizienzbetrachtungen bei der Lösung der Aufgabe keine Rolle spielen, wählen wir einen einfachen, aber ineffizienten Algorithmus mit zwei ineinander verschachtelten for-schleifen. Dadiefor-Schleifen

Mehr

Verifikation von Algorithmen. OOPM, Ralf Lämmel

Verifikation von Algorithmen. OOPM, Ralf Lämmel Verifikation von Algorithmen OOPM, Ralf Lämmel Wiederholung: Was tun? (Mit den Spezifikationen) Dokumentation Überprüfen der Bedingungen zur Laufzeit Verifizieren der Bedingungen vor Laufzeit Ableitung

Mehr