30 likes | 90 Views
. . . Übung 6.3 Denksportaufgabe. Gegeben sei folgendes Verfahren
E N D
Übung 6.3 Denksportaufgabe • Gegeben sei folgendes Verfahren In einem Topf seien s schwarze und w weiße Kugeln - insgesamt mindestens eine. Solange mindestens zwei Kugeln im Topf sind, nimm zwei beliebige Kugeln heraus. Falls Sie gleiche Farbe haben, wirf beide weg und lege eine neue schwarze Kugel in den Topf. Falls sie verschiedene Farben haben, wirf die schwarze weg und lege die weiße zurück in den Topf. • Welche Farbe hat die letzte Kugel • Welche Aussage - die einen Hinweis auf die Antwort gibt - gilt vor, in und nach der Schleife (Invariante) • Terminiert die Schleife ? Begründen Sie ihre Antwort.
Übung 6.4 Invariante • Betrachten Sie nochmals das Verfahren aus der vorgegangenen Übung: In einem Topf seien s schwarze und w weiße Kugeln - insgesamt mindestens eine. Solange mindestens zwei Kugeln im Topf sind, nimm zwei beliebige Kugeln heraus. Falls Sie gleiche Farbe haben, wirf beide weg und lege eine neue schwarze Kugel in den Topf. Falls sie verschiedene Farben haben, wirf die schwarze weg und lege die weiße zurück in den Topf. • Beschreiben Sie das Verfahren als Algorithmus • Das „Nehmen“ dürfen Sie als Block voraussetzen. • Entwerfen Sie den Kopf dieses Blocks, • Beschreiben Sie seine Parameter • beschreiben Sie sein Verhalten in Form einer Vor- und Nachbedingung • Bestimmen Sie die Invariante • Beweisen Sie die Korrektheit Ihrer Nachbedingung
Übung 6.5 Vollständige Verifikation • gegeben ist der folgende Algorithmus zum schnellen Potenzieren (Legendre Algorithmus) // Vorbedingung P(V): a>0 b0x = a; y = b; z = 1; while y > 0 { if odd(y) then z = z*x; y = y div 2; // Ganzzahldivision x = x*x;} • Was ist die Nachbedingung dieses Algorithmus • Bestimmen die die Schleifeninvariante • Beweisen Sie die Korrektheit de Legendre Algorithmus