| Formale Verifikation - AufgabenAufgaben |   | 
Aufgabe 1: Was tut das folgende Programmstück?
| x=x+y; y=x-y; x=x-y; | 
Aufgabe 2: Beweisen Sie
| { x < y } | |
| x=y-x; | |
| x=y+x; | |
| { y < x } | 
Lösung:
| { x < y } | |
| { y + x < y + y } | |
| { y < y + y – x } | |
| x=y-x; | |
| { y < y + x } | |
| x=y+x; | |
| { y < x } | 
Aufgabe 3: Gegeben sei folgendes Programmstück X mit int-Variablen a, b, x, y und r:
| 
x=a;
y=b;
while (y!=0)
{
    r=x%y;
    x=y;
    y=r;
}
 | 
Das Programm soll den größten gemeinsamen Teiler von a und b berechnen.
Beweisen Sie die partielle Korrektheit von X bezüglich der Vorbedingung Q: true und der Nachbedingung
R:   ggt(a, b) = ggt(x, y)   y = 0.
  y = 0.
Aus der Nachbedingung folgt, dass x der größte gemeinsame Teiler von a und b ist, denn es gilt
ggt(a, b) = ggt(x, y)   y = 0
  y = 0    ggt(a, b) = ggt(x, 0) = x.
   ggt(a, b) = ggt(x, 0) = x.
Benutzen Sie beim Beweis des Schleifenkörpers, dass
ggt(x, y) = ggt(y, x mod y)
gilt, falls y ≠ 0 ist.
Aufgabe 4:  Beweisen Sie die totale Korrektheit des Programmstücks X aus der vorigen Aufgabe bezüglich der Vorbedingung Q:  b 0 und der Nachbedingung
0 und der Nachbedingung 
R:   ggt(a, b) = ggt(x, y)   y = 0.
  y = 0.
| Weiter mit:  | 
|  H.W. Lang   Hochschule Flensburg   lang@hs-flensburg.de   Impressum   © |  |