1. Grundlagen der Informatik

Ähnliche Dokumente
Inhalt. 1. Einführung in die Informatik. 2. Algorithmen Definition, Eigenschaften, Entwurf Darstellung von Algorithmen Beispiele.

Inhalt. 3. Spezielle Algorithmen

Inhalt. 3. Spezielle Algorithmen

einseitige Selektion zweiseitige Selektion

Informatik. Teil 1 - Sommersemester Prof. Dr.-Ing. habil. Peter Sobe Fachkultät Informatik / Mathematik

Informatik. Teil 1 Wintersemester 2011/2012. Prof. Dr.-Ing. habil. Peter Sobe Fachkultät Informatik / Mathematik

Einschub: Anweisungen und Bedingungen für PAP und Struktogramme (1)

Informatik I. Teil 1 - Wintersemester 2010/11. Prof. Dr.-Ing. habil. Peter Sobe Fachkultät Informatik / Mathematik. Inhalt

1. Grundlegende Konzepte der Informatik

Inhalt. 1. Einführung in die Informatik. 2. Algorithmen Definition, Eigenschaften, Entwurf Darstellung von Algorithmen Beispiele.

Rekursive Algorithmen

Inhalt. 1. Einführung in die Informatik. 2. Algorithmen Definition, Eigenschaften, Entwurf Darstellung von Algorithmen Beispiele.

Inhalt. 1. Einführung in die Informatik. 2. Algorithmen Definition, Eigenschaften, Entwurf Darstellung von Algorithmen Beispiele.

2. Die Darstellung von Algorithmen

Informatik 1. Teil 1 - Wintersemester 2012/2013. Prof. Dr.-Ing. habil. Peter Sobe Fachkultät Informatik / Mathematik

Flussdiagramm / Programmablaufplan (PAP)

2. Algorithmenbegriff

Anweisungen und Kontrollstrukturen

Anweisungen und Kontrollstrukturen

Algorithmen und Datenstrukturen (für ET/IT)

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

Algorithmen und deren Beschreibung

2. Programmierung in C

Javakurs für Anfänger

Kapitel 10. Komplexität von Algorithmen und Sortieralgorithmen

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

FHZ. K13 Rekursion. Lernziele. Hochschule Technik+Architektur Luzern Abteilung Informatik, Fach Programmieren. Inhalt

Methoden. Gerd Bohlender. Einstieg in die Informatik mit Java, Vorlesung vom

Prozedurales Programmieren und Problemlösungsstrategien

Klassenvariablen, Klassenmethoden

Algorithmen & Programmierung. Rekursive Funktionen (1)

2. Einführung in das Ingenieurtool MATLAB

2. Programmierung in C

1. Der Begriff Informatik 2. Syntax und Semantik von Programmiersprachen - 1 -

1. Der Begriff Informatik 2. Syntax und Semantik von Programmiersprachen - 1 -

Arbeitsblätter für Algorithmierung und Strukturierung

1. Grundlegende Konzepte der Informatik

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

Einstieg in die Informatik mit Java

Einführung in die Informatik I

Einstieg in die Informatik mit Java

Komplexität von Algorithmen

Inhaltsverzeichnis. Einführende Bemerkungen 11. Das Fach Informatik 11 Zielsetzung der Vorlesung Grundbegriffe

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

zu große Programme (Bildschirmseite!) zerlegen in (weitgehend) unabhängige Einheiten: Unterprogramme

BKTM - Programmieren leicht gemacht.

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

1. Teilklausur. Name:... Vorname:... Matrikel-Nummer:...

zu große Programme (Bildschirmseite!) zerlegen in (weitgehend) unabhängige Einheiten: Unterprogramme

Wissenschaftliches Rechnen

n 1. Der Begriff Informatik n 2. Syntax und Semantik von Programmiersprachen - 1 -

Programmieren 1 C Überblick

1. Grundlagen der Informatik Boolesche Algebra / Aussagenlogik

Labor Software-Entwicklung 1

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

5. Übung - Kanalkodierung/Programmierung

Konzepte der Informatik

1 Algorithmische Grundlagen

Martin Unold INFORMATIK. Geoinformatik und Vermessung

Arbeitsblätter für Algorithmierung und Strukturierung C #

EINI LW. Einführung in die Informatik für Naturwissenschaftler und Ingenieure. Vorlesung 2 SWS WS 11/12

Großübung 2 und 3: Struktogramme

Einfache Bedingte Ausführung

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

Operatoren (1) Operatoren (2)

Kapitel 9. Komplexität von Algorithmen und Sortieralgorithmen

Inhalt. Einführung in die Strukturierte Programmierung 15

Kapitel 9. Komplexität von Algorithmen und Sortieralgorithmen

Imperative Programmierung in Java: Kontrollfluß II

Grundlagen der Informatik I (Studiengang Medieninformatik)

Kapitel 1: Informationsverarbeitung durch Programme

Grundlagen der Programmierung

Einführung in die C++ Programmierung für Ingenieure

5. Strukturierte Programmierung

Analysis für Informatiker

Einführung in die Programmierung für NF. Übung

Struktogramme. Hinweise 1 Stand:

Informatik 1. Sommersemester Helmut Seidl. Institut für Informatik TU München

2. Programmierung in C

Javakurs für Anfänger

Einstieg in die Informatik mit Java

Sommersemester Jewgeni Rose. Technische Universität Braunschweig

Kap 7. Funktionen und Arrays

Algorithmen und Datenstrukturen Sommersemester 2007

Turing-Maschinen: Ein abstrakes Maschinenmodell

Programmierung mit C Algorithmen

Einführung in die Informatik I (autip)

Syntax von Programmiersprachen

2 Eine einfache Programmiersprache

1. Die rekursive Datenstruktur Liste

2 Eine einfache Programmiersprache. Variablen. Operationen Zuweisung. Variablen

Funktionen. mehrfach benötigte Programmteile nur einmal zu schreiben und mehrfach aufzurufen

Transkript:

1. Grundlagen der Informatik Inhalt Organisation und Architektur von Rechnern Boolesche Algebra / Aussagenlogik Zahlensysteme und interne Informationsdarstellung Algorithmen, Darstellung von Algorithmen, Programmierung Peter Sobe 1

Algorithmen Einführende Beispiele Täglich werden Verarbeitungsvorschriften ausgeführt, die einen Weg beschreiben, wie ein gewünschtes Ergebnis erzielt werden kann. Solche Vorschriften sind: Bedienungsanleitungen zum Beispiel zur Bedienung eines Parkscheinautomaten Montageanleitungen Aufbau von Möbelstücken, Beispiele im Modellbaukasten Verhaltensvorschriften Verhalten bei Unfällen, Feueralarm, usw. Rezepte Mischen von Farben, Kochrezepte, usw. Rechenvorschriften Lösen eines Gleichungssystems, Berechnung eines elektrischen Stromkreises, Bestimmung von Flächeninhalten, usw. Peter Sobe 2

Algorithmen Definition: Ein Algorithmus ist eine Vorschrift zur Lösung einer Klasse von Problemen. Er besteht aus einer endlichen Folge von Schritten, mit der aus bekannten Eingangsdaten neue Ausgangsdaten eindeutig berechnet werden können. Eigenschaften: Die Definition zeigt den engen Zusammenhang mit Funktionen (Eingangsdaten Ausgangsdaten). Die Definition bindet den Algorithmus an die Lösung einer Klasse von Problemen und nicht an eine einzelne Aufgabe. Problem: Die Definition eines Algorithmus enthält keine Forderungen an die praktische Ausführbarkeit des Algorithmus auf einer realen Maschine (Rechner). Peter Sobe 3

Algorithmen als mathematische Funktionen Ein Algorithmus kann als Funktion (mathematische Definition) aufgefasst werden. y=f(x) oder f: D Z, x y (D: Definitionsmenge, Z: Zielmenge) In der Mathematik ist eine Funktion oder Abbildung eine Beziehung zwischen zwei Mengen, die jedem Element der einen Menge (Funktionsargument, unabhängige Variable, x-wert) genau ein Element der anderen Menge (Funktionswert, abhängige Variable, y-wert) zuordnet. (Quelle: de.wikipedia.org) Interpretation: Elemente aus Mengen: Eingabe und Ausgabe Die Elemente können auch Mengen, Vektoren o.ä. sein Peter Sobe 4

Beispiele berechenbarer Funktionen / Algorithmen a) Berechne alle Primzahlen im Intervall [1,100]! Dieses Beispiel stellt eine berechenbare Funktion dar, der Algorithmus ist relativ einfach. b) Berechne die Funktionswerte der Funktion f(x+1) = 2 f(x) mit f(0)=0 für 6<=x<=12! Dies ist auch eine berechenbare Funktion, die sich aber auf keiner realen Rechenmaschine abarbeiten lässt, da f(6) bereits eine Zahl mit 19000 Dezimalstellen ist. Manche Funktionen sind unter realistischem Ressourcen- und Zeitaufwand nicht auf einem Rechner umsetzbar, obwohl sie prinzipiell berechenbar sind. Peter Sobe 5

Charakteristische Eigenschaften von Algorithmen Endlichkeit Ein Algorithmus muss aus einer endlichen Anzahl von Lösungsschritten bestehen und nach Abarbeitung dieser endlich vielen Schritte nach einer endlichen Zeit das Ende erreichen. Eindeutigkeit Die einzelnen Schritte eines Algorithmus und ihre Aufeinanderfolge müssen eindeutig beschrieben sein. Allgemeinheit Ein Algorithmus darf nicht nur die Lösung einer speziellen Aufgabe (z.b. Lösung der Gleichung x² + 2x + 1=0), sondern muss die Lösung einer Klasse von Problemen (z.b. die Lösung aller quadratischen Gleichungen ax² +bx +c =0) beschreiben. Peter Sobe 6

Charakteristische Eigenschaften von Algorithmen Determiniertheit ( für deterministische Algorithmen) Die mehrmalige Anwendung des Algorithmus mit denselben Eingangsdaten muss immer wieder dieselben Ausgangsdaten liefern. Hinweis: Es gibt auch nichtdeterministische Algorithmen Effizienz Ein Algorithmus muss möglichst wenig Ressourcen einer Maschine, d.h. möglichst wenig Rechenzeit und möglichst wenig Speicher in Anspruch nehmen. In der Informatik wurden Effizienzmaße für Algorithmen, die sogenannte Zeit- und Speicherkomplexität entwickelt, mit der Algorithmen bewertet werden können. Dies ist praktisch sehr wichtig, da oft zur Berechnung einer Funktion mehrere Algorithmen angegeben werden können. Peter Sobe 7

Die Darstellung von Algorithmen Aus den Einführungsbeispielen und Übungsaufgaben ist erkennbar, dass zur Darstellung von Algorithmen Grundelemente notwendig sind. Neben der Notation einzelner elementarer Aktionen/Anweisungen, wie z.b. - Gebe die Werte der Koeffizienten a,b,c ein sind auch logische Elementarstrukturen notwendig, die die zeitliche Ablauffolge darstellen, wie z.b. die Folge (Sequenz) von Anweisungen, wie z.b. 1. Gebe die Werte der Koeffizienten a,b,c ein 2. Berechne d = b*b 4*a*c aber auch die Auswahl (Selektion) 3. Falls d<0 setze fort mit Schritt 7 Peter Sobe 8

formale Darstellung von Algorithmen Bei der Darstellung von Algorithmen liegt der Schwerpunkt vor allem auf der Darstellung der zeitlichen Ablauffolge, dem sogenannten Steuerfluss und nicht auf der Darstellung der einzelnen elementaren Anweisung an sich. Theorem von Böhm und Jacopini Mit nur drei logischen Elementarstrukturen - Sequenz - Selektion - Zyklus lässt sich jedes algorithmierbare Problem darstellen. Peter Sobe 9

formale Darstellung von Algorithmen Es wurden zwei verschiedene Darstellungsformen entwickelt, die hauptsächlich in Gebrauch sind und auf grafische Symbole zurückgreifen: Programmablaufplan (abk. PAP) nach DIN 66001 (vgl. Bild 1) Struktogramm nach Nassi und Shneiderman nach DIN 66261 (vgl. Bild 2) Beide repräsentieren eine sogenannte Syntax, die die Ausdrucksformen der Beschreibung formal spezifiziert. Die Bedeutung der Darstellung wird als Semantik bezeichnet. Peter Sobe 10

Ein Algorithmus als Programmablaufplan Start 1 E: Kredit, Zinssatz Kredit > 0 nein Zinsen=Kredit * Zinssatz/100 E: Rate ja Jahre=Jahre +1 Zinsen=Kredit * Zinssatz/100 Kredit < 0 ja Rate=Rate + Kredit nein Rate>Zinsen ja nein Kredit=Kredit +Zinsen - Rate A: letzte Rate=, Rate Jahre=0 Zinssumme=Zinssumme+Zinsen Zinssumme=0 1 A: Laufzeit=,Jahre, Jahre, Zinssumme=, Zinssumme Stop Peter Sobe 11

Struktogramm Algorithmus als Struktogramm Eingabe: Kredit, Zinssatz Zinsen=Kredit * Zinssatz/100 Eingabe: Rate Wiederhole bis Rate > Zinsen Jahre=0 Zinssumme=0 Wiederhole solange Kredit > 0 ja Jahre=Jahre +1 Zinsen=Kredit * Zinssatz/100 Kredit=Kredit +Zinsen - Rate Zinssumme=Zinssumme+Zinsen Kredit < 0 Rate=Rate + Kredit Ausgabe: letzte Rate=, Rate / nein Peter Sobe Ausgabe: Laufzeit=,Jahre, Jahre, Zinssumme=, Zinssumme 12

Sequenz Struktogramm Programmablaufplan Anw_1 Anw_2... Anw_n Anw_1 Anw_2... Anw_n Das Wesentliche einer Sequenz besteht darin, dass sie nach außen wiederum nur eine einzige Aktion/Anweisung repräsentiert, obwohl sie intern aus einer Folge von Anweisungen (Anw) besteht. Peter Sobe 13

einseitige Selektion Struktogramm Programmablaufplan ja Bedingung nein Anw / Bedingung ja Anw nein Die einseitige Selektion gestattet die Ausführung einer Anweisung Anw (welche wiederum eine Sequenz sein kann), wenn die angegebene Bedingung wahr (ja) ist. Die Bedingung ist ein aussagenlogischer Ausdruck. Peter Sobe 14

zweiseitige Selektion Struktogramm Programmablaufplan Bedingung ja nein Anw_1 Anw_2 Bedingung ja Anw_1 nein Anw_2 Die zweiseitige Selektion gestattet die Auswahl einer Anweisung (welche wiederum eine Sequenz sein kann) aus zwei angegebenen Sequenzen Anw_1 bzw. Anw_2. Wenn die angegebene Bedingung wahr (ja) ist, wird Anw_1 ausgeführt, sonst Anw_2. Peter Sobe 15

mehrfache Selektion ohne Sonst- Zweig Fallausdruck Wert 1 Wert 2... Wert N Anw_1 Anw_2... Anw_n Dieses Konstrukt besitzt in der PAP- Darstellung keine direkte Entsprechung! Der Fallausdruck kann einfache Werte repräsentieren, z.b. ganzzahlige oder dezimale Werte, ein Zeichen, eine Zeichenkette. Für alle zu behandelnden Fälle wird eine entsprechende Konstante als Wert 1, Wert 2 usw. angegeben. Entsprechend dem zutreffenden Wert wird eine angegebene Anweisung ausgeführt, also Anw_1 oder Anw_2 usw. Peter Sobe 16

mehrfache Selektion mit Sonst-Zweig Fallausdruck Wert 1 Wert 2... Wert N sonst Anw_1 Anw_2... Anw_n Anw_0 Die Semantik entspricht im Prinzip der mehrfachen Selektion ohne Sonst-Zweig mit der Erweiterung, dass wenn der Fallausdruck keinen der angegebenen Werte Wert 1, Wert 2,... repräsentiert, wird dann die Anweisung Anw_0 ausgeführt. Peter Sobe 17

Zyklus abweisend Struktogramm Programmablaufplan Wiederhole, solange Bedingung wahr ist Anw Bedingung ja Anw nein Die Ausführung einer Anweisung Anw (welche wiederum eine Sequenz sein kann), wird solange wiederholt ausgeführt, solange die angegebene Bedingung wahr (ja) ist. Abweisend bedeutet, dass wenn die Bedingung bei Eintritt bereits falsch ist, wird Anw überhaupt nicht ausgeführt. Peter Sobe 18

Zyklus nicht abweisend Struktogramm Programmablaufplan Anw Wiederhole, solange Bedingung wahr ist Anw Bedingung ja nein Die Ausführung des Zyklus beginnt mit der Ausführung der Anweisung Anw (welche wiederum eine Sequenz sein kann), ohne Prüfung der Bedingung (deshalb nicht abweisend ). Erst nach der Ausführung von Anw wird die angegebene Bedingung geprüft. Ist die Bedingung wahr, wird die Anweisung Anw wieder ausgeführt. Das wird wiederholt, solange die angegebene Bedingung wahr (ja) ist. Peter Sobe 19

Zähl-Zyklus Struktogramm Programmablaufplan Lv = awert (s) ewert Anw Lv die ist sogenannte Laufvariable awert ist der Anfangswert von Lv s ist die Schrittweite ewert ist der Endwert von Lv Lv = awert Lv<=ewert ja Anw Lv = Lv + s nein Die Anweisung Anw erfährt eine bestimmte Anzahl von Wiederholungen, die sich aus den Größen awert, s und ewert ergibt. Peter Sobe 20

Prozedur-Deklaration Struktogramm Programmablaufplan Funktion(Parameterliste) Funktion(Parameterliste) Anw als Teilalgorithmus Anw als Teilalgorithmus Funktion ist der Name eines Teilalgorithmus. Alle Größen, die der return Algorithmus aus der Umgebung zur Abarbeitung benötigt, müssen in der Parameterliste definiert werden. In der Parameterliste müssen Eingangs- und Ausgangsgrößen unterschieden werden. Peter Sobe 21

Prozedur-Aufruf Struktogramm Programmablaufplan Eingangsgrößen Funktion(Argumentliste) Funktion Ausgangsgrößen Die Argumente sind die in einer Umgebung gültigen Objekte, die für Parameter beim Aufruf eingesetzt werden. Dabei müssen in der Argumentliste Eingangs- und Ausgangsgrößen unterschieden werden. Peter Sobe 22

Hilfsgrößen bei Programmablaufplänen Anfang / Ende eines Hauptprogrammes Start Stop Anschlußstelle (Konnektor) zwischen zwei Programmablaufplanteilen A A Peter Sobe 23

Notation von Anweisungen und Bedingungen für PAP und Struktogramme (1) Anweisungen: Eingabeanweisungen, z.b. Eingabe: x Ausgabeanweisungen, z.b. Ausgabe: Das Maximum ist, max Die Symbole x und max werden hier für Variablen benutzt. Variablen nehmen Daten während der Abarbeitung des Programms auf. Eingabe: x Ausgabe: Das Maximum ist, max Peter Sobe 24

Notation von Anweisungen und Bedingungen für PAP und Struktogramme (2) Anweisungen: Zuweisungen konstanter Werte, z.b. z = 5 Zuweisungen im Stil mathematischer Ausdrücke, z.b. y = z * 2. Hier wird der Variable y der Wert zugewiesen, der sich aus z*2 errechnet. Allgemein wird der links von = stehenden Variablen der Wert des Ausdrucks rechts zugewiesen. z = 5 y = z * 2 Nicht gültig: x+y = 10*z Das ist keine Zuweisung, obwohl es ein möglicher mathematischer Ausdruck ist. Peter Sobe 25

Notation von Anweisungen und Bedingungen für PAP und Struktogramme (3) Bedingungen: Als Frage formuliert, ob eine Variable einen bestimmten Wert aufweist, z.b. z = 0?. Die Bedingung ist dann erfüllt, wenn z den Wert 0 besitzt. Als Gleichung formuliert, z.b. y = z * z?. Wenn die linke und rechte Seite der Gleichung den gleichen Wert ergeben, dann ist die Bedingung erfüllt. Als Ungleichung formuliert, z.b. y > z. Nur bei ungleicher linker und rechter Seite ist die Bedingung erfüllt. z = 5 ja nein Achtung: Ein Ausdruck wirkt unterschiedlich, je nach dem, ob er in einer Anweisung oder in einer Bedingung verwendet wird. Peter Sobe 26

Notation von Anweisungen und Bedingungen für PAP und Struktogramme (4) Felder: Algorithmen arbeiten oft auf Feldern, die N einzelne Variable als Folge enthalten, z.b. z 1, z 2, z 3, z N Die einzelnen Elemente können im PAP oder Struktogramm mit Index angegeben werden. Der Index kann ein konkreter Wert sein (z.b. z 1 ) oder auch als Variable angegeben werden (z.b. z i ). a 1 = 0 i = 5 a i = a i-1 * a i-1 z i = 0? ja nein Peter Sobe 27

Notation von Anweisungen und Bedingungen für PAP und Struktogramme (5) Felder (Fortsetzung): Der Index kann auch mit Indexklammern geschrieben werden, z.b. z[1] oder z[i-1]. a[1] = 0 i = 5 a[i] = a[i-1]* a[i-1] z[i] = 0 ja nein Peter Sobe 28

Spezielle Algorithmen Im folgenden Abschnitt sollen ausgewählte Algorithmen, die spezielle Konstrukte des algorithmischen Paradigmas, wie - Selektion, Mehrfachselektion - Zyklen verschiedener Formen enthalten, entwickelt und besprochen werden. In einem weiteren Abschnitt werden dann Algorithmen mit Prozeduren und Funktionen behandelt und schließlich werden rekursive Algorithmen dargestellt. Peter Sobe 29

Algorithmen mit Selektion Algorithmen, die nur die Konstrukte Sequenz und Selektion (einschließlich Mehrfachselektion) enthalten sind eigentlich sehr einfache Algorithmen, wenn man einmal ausschließt, dass Prozeduren aufgerufen werden. Die meisten anspruchsvollen Algorithmen enthalten Zyklen. Beispiel 1: Prüfen der Seitenlängen eines Dreiecks und anschließende Berechnung des Flächeninhalts. Ein Dreieck mit den Seiten a,b,c hat einen Flächeninhalt f= mit s=(a+b+c)/2 s* ( s a)*( s b)*( s c) Es ist zu prüfen, ob mit den Seiten wirklich ein Dreieck gebildet werden kann! Peter Sobe 30

Algorithmen mit Selektion Beispiel 1: Ein Dreieck kann nur dann gebildet werden, falls a+b>c und a+c>b und b+c>a gilt. Damit können wir folgenden Algorithmus angeben: Eingabe: a,b,c ja s=(a+b+c)/2 (a+b>c) UND (a+c>b) UND (b+c>a) f=sqrt(s*(s-a)*(s-b)*(s-c)) Ausgabe: "Fläche= ",f Ausgabe: " Dreieck existiert nicht" nein Peter Sobe 31

Algorithmen mit Selektion Beispiel 2: Ein Algorithmus, der von zwei natürlichen Zahlen x und y ermittelt, ob die eine ein Teiler der anderen ist. Beispiel 3: Ein Algorithmus, der ein eingegebenes Datum, bestehend aus den drei Größen t für Tag, m für Monat und j für Jahr, überprüft und ausgibt, ob es sich um ein gültiges Datum aus dem Zeitraum 1583 bis 2100 handelt. Dazu ist das Datum auf einfache Plausibilität zu prüfen, aber auch der Tag in Bezug auf den Monat zu prüfen. Lösungen zu den Beispielen 2 und 3 werden an der Tafel demonstriert, oder sind Gegenstand der Übung. Peter Sobe 32

Algorithmen mit Selektion und Zyklen Zyklen in Algorithmen werden benutzt, um mehrere Datenelemente (Elemente innerhalb Mengen, Reihen, Feldern, Vektoren, Matrizen) nacheinander zu verarbeiten. sind nötig für schrittweise Lösungsverfahren, die sich durch die wiederholte Ausführung einer Regel einer Lösung annähern. werden für Verfahren verwendet, die kontinuierlich neue Daten einlesen und verarbeiten Peter Sobe 33

Algorithmen mit Selektion und Zyklen Beispiel 4: (Basisalgorithmus mit Zählschleife) Es ist ein Algorithmus zur Bestimmung des Minimums einer Zahlenfolge a 1, a 2,... a n aufzustellen. Lösung: Mitschrift Beispiel 5: (Basisalgorithmus mit geschachtelten Zählschleifen) Es ist eine Weiterentwicklung des Algorithmus 4 vorzunehmen, der eine gegebene Zahlenfolge sortiert, indem er das Minimum bestimmt, an die Position 1 setzt und dann mit dem Rest (ab Position 2) wieder das Minimum bestimmt usw. Lösung: Mitschrift Peter Sobe 34

Sortieren durch Iteration (1) Quicksort (als rekursiver Algorithmus) ist ein sehr schneller Sortieralgorithmus, aber ist nicht einfach zu durchschauen. Im folgenden soll ein sehr einfacher intuitiver Sortieralgorithmus angegeben werden. Bubble Sort Eingabe: feld a mit Elementen a[1] bis a[n], Feldlänge n Ausgabe: feld a mit sortierten Elementen Idee: (1) Durchlaufe Feld mit aufsteigendem Index und vertausche benachbarte Felder, falls Sie nicht der geforderten Sortierreihenfolge entsprechen. Wiederhole (1) solange, bis keine Vertauschungen mehr nötig sind Peter Sobe 35

Sortieren durch Iteration (2) Bubble Sort PAP (ohne Eingabe) Start tausch=0 i = 1 i<n nein ja a[i]>a[i+1] ja tausch =1 nein tmp = a[i] a[i] = a[i+1] nein ja a[i+1] = tmp Stop tausch = 1 i = i+1 Peter Sobe 36

Rekursive Algorithmen In der Mathematik sind viele Funktionen rekursiv definiert. Der Begriff der Rekursion beinhaltet, dass zur Definition einer Funktion diese selbst wieder mit benutzt wird, allerdings mit anderen Argumenten. Eine rekursive Definition benötigt stets eine (nichtrekursive) Anfangs- bzw. Abbruchbedingung. Beispiel: Fakultät rekursive Definition : fak(n) = n * fak(n-1) Anfangsbedingung: fak(0) = 1 Peter Sobe 37

Rekursive Algorithmen - Charakteristika Eine solche Definition ist in der Regel kurz und übersichtlich. Man erkennt sofort die Grundstruktur des Algorithmus. Eine solche rekursive Definition lässt sich auch sehr leicht unter Verwendung rekursiver Prozeduren (Funktionen in C) implementieren. Allerdings ist der implementierte Algorithmus häufig ineffizient, d.h. mit einem hohen Ressourcenverbrauch (Speicher und Rechenzeit) verbunden. Bestimmte rekursive Algorithmen lassen sich in iterative Algorithmen umschreiben und damit effizienter implementieren. Dies trifft insbesondere auf eine sogenannte endständige Rekursion zu, wie z.b. bei der Berechnung der Fakultät. fak(0)=1; fak(n) = n * fak(n-1); Peter Sobe 38

Rekursive Algorithmen - Fakultät Das folgende Struktogramm enthält die Umsetzung der rekursiven Definition: fak(n, f) Eingabe: n Ausgabe: f = n! ja f = 1 n<2 fak( n-1, t ) f = n * t nein Peter Sobe 39

Rekursive Algorithmen Fibonacci-Zahlen Rekursive Definition der Fibonacci-Zahlen: fibo(n) = fibo(n-1) + fibo(n-2) Anfangsbedingung: fibo(1)=1, fibo(2)=1 Das folgende Struktogramm benutzt die Rückkehr aus dem Unterprogramm: return return gibt einen Wert zurück, so dass z.b. x = fibo(5) geschrieben werden kann. fibo(n) Eingabe: n Ausgabe: Rückkehrwert ja n<3 nein return 1 return (fibo(n-1)+ fibo(n-2)) Peter Sobe 40

Rekursive Algorithmen Turm von Hanoi Das Problem beim Turm von Hanoi besteht in der folgenden Aufgabe: 1. Gegeben ist ein Turm auf einem Standplatz A aus n Scheiben, die übereinander liegen, und zwar immer eine kleinere auf einer größeren Scheibe. 2. Der Turm soll auf einen zweiten Platz B umgesetzt werden, wobei aber beim Umsetzen immer nur eine kleinere auf eine größere Scheibe gelegt werden darf. 3. Bei der Umsetzung darf ein dritter Hilfsplatz C mitbenutzt werden. Das C-Programm für dieses Problem wird in der Vorlesung vorgeführt. Es dient als Experimentierprogramm für einen Turm mit einer wählbaren Scheibenanzahl zum Studium der Aufgabenstellung. Peter Sobe 41

Rekursive Algorithmen Turm von Hanoi Analysiert man das Problem beim Turm von Hanoi so erkennt man, dass man beim Umsetzen des Turms von n Scheiben vom Platz A zum Platz B erst einmal den Turm von n-1 Scheiben über der größten Scheibe von A nach dem Hilfsplatz C umsetzen muss, um einen Zug der größten Scheibe vom Platz A zum Platz B vornehmen zu können. Danach muss der Turm von n-1 Scheiben vom Platz C wieder auf den Platz B umgesetzt werden. Peter Sobe 42

Rekursive Algorithmen Turm von Hanoi Platz A Platz B Platz C Ausgangssituation Turm soll nach Platz B umgesetzt werden Peter Sobe 43

Rekursive Algorithmen Turm von Hanoi Platz A Platz B Platz C Turm mit n-1 Scheiben über der größten Scheibe muss auf Hilfsplatz C umgesetzt werden. Peter Sobe 44

Rekursive Algorithmen Turm von Hanoi Platz A Platz B Platz C Größte Scheibe kann jetzt durch einen Zug vom Platz A zum Platz B befördert werden. Peter Sobe 45

Rekursive Algorithmen Turm von Hanoi Platz A Platz B Platz C Turm mit n-1 Scheiben kann jetzt vom Hilfsplatz C zum Platz B umgesetzt werden. P. Sobe 46

Rekursive Algorithmen Turm von Hanoi Algorithmus rekursiv: Umsetz(n,a,b) = Umsetz(n-1,a,k), Zug (n,a,b), Umsetz(n-1,k,b) Die Rolle des Hilfsplatzes k wechselt von Ebene zu Ebene. Hilfsplatz ist immer der Platz, der in der Umsetzung nicht genannt ist. Bei Umsetz(...,A,C) ist es in der nächsten Ebene der Platz B usw.. Bezeichnet man den Platz A mit der Ziffer 0, den Platz B mit der Ziffer 1, und den Platz C mit der Ziffer 2, so kann der freie Platz immer mit k=3-a-b bezeichnet werden. Peter Sobe 47

Rekursive Algorithmen Turm von Hanoi Struktogramm rekursiv: umsetzen (n, a, b) ja n = 0 k = 3 - a - b nein / umsetzen (n-1, a, k) zug (n, a, b) umsetzen (n-1, k, b) Peter Sobe 48

Rekursive Algorithmen Turm von Hanoi Struktogramm für Unterprogramm zug: zug( n, a, b) Ausgabe: "snr=",n,"von ",p[a],"->",p[b] Die Ausgabe benutzt ein Feld p: A B C Peter Sobe 49