faecher:informatik:oberstufe:automaten:lepro:erstellung2:start

Unterschiede

Hier werden die Unterschiede zwischen zwei Versionen angezeigt.

Link zu dieser Vergleichsansicht

Beide Seiten der vorigen Revision Vorhergehende Überarbeitung
Nächste Überarbeitung
Vorhergehende Überarbeitung
faecher:informatik:oberstufe:automaten:lepro:erstellung2:start [23.09.2020 17:40] – [Beispiel] sbelfaecher:informatik:oberstufe:automaten:lepro:erstellung2:start [Unbekanntes Datum] (aktuell) – gelöscht - Externe Bearbeitung (Unbekanntes Datum) 127.0.0.1
Zeile 1: Zeile 1:
-====== Automaten Entwerfen II - formale Sprachen ====== 
-===== Übersicht ===== 
  
-Automaten werden z. B. als Grundlage für Compiler verwendet. Ein Compiler soll erkennen, ob die Syntax der in den Computer eingegebenen Codes richtig ist. Der zugrundeliegende Automat muss also gewährleisten, dass nur Codebausteine, die programmiersprachenkonform sind, akzeptiert werden. Ein solcher Automat muss somit eine vorgegebene 
-"Sprache" akzeptieren.  
- 
-===== Lernziel ===== 
- 
-Nach diesem Kapitel kannst du ... 
-  * endliche Automaten als Graphen darstellen. 
-  * natürliche und formale Sprachen unterscheiden und außerdem Begriffe einer formalen Sprache wie z. B. Sprache des Automaten oder Wort verwenden. 
-  * Sprachen von Automaten beschreiben. 
-  * zu einer gegebenen Sprache einen Automaten konstruieren. 
- 
- 
-====== Los gehts... ====== 
- 
-Du hast bis jetzt viele verschiedene Automaten kennengelernt. Außerdem hast du im letzten Kapitel 
-gelernt, wie man Automaten verändert und damit auch das Akzeptanzverhalten des Automaten beeinflusst. Auf diesem Wissen baust du nun auf, denn jetzt konstruierst du deinen Automaten von Grund 
-auf selber! Lies dazu zunächst noch ein Beispiel durch: 
- 
-Es soll ein Automat konstruiert werden, der eine vierstellige Zahl übergeben bekommt. Der Automat 
-soll diese Zahl akzeptieren, wenn sie gerade ist und sie verwerfen, wenn sie ungerade ist. Man kann 
-diesem Automaten außerdem ausschließlich vierstellige Zahlen übergeben; so muss zum Beispiel für 
-die Zahl 100 die vierstellige Zahl 0100 eingegeben werden. Die vorderen Nullen haben dabei keinerlei 
-Bedeutung. 
- 
-Wie muss aber ein Automat aussehen, der nur gerade Zahlen akzeptiert? 
-Natürlich ist bei dieser Frage nur die letzte Ziffer der Zahl interessant, denn schon an dieser kann man 
-ablesen, ob eine Zahl gerade ist, oder nicht. Die ersten drei Ziffern der Zahl sind also für den Automaten uninteressant. Das lässt sich folgendermaßen darstellen: 
- 
-{{ :faecher:informatik:oberstufe:automaten:lepro:erstellung2:gerade03.png?500 |}} 
- 
-Dieser Automat "zählt" praktisch nur die ersten drei Ziffern drei und ignoriert alle anderen Eigenschaften der Eingaben. Nur die letzte, die vierte Ziffer, ist von Bedeutung für unser Beispiel. Denn wenn diese Ziffer gleich 0, 2, 4, 6, oder 8 ist, ist die Zahl gerade. Unser Automat soll in diesem Fall die Zahl somit akzeptieren. 
- 
- 
-Ist die letzte Ziffer eine 1, 3, 5, 7 oder 9 – ist die Zahl also ungerade – soll der Automat die Zahl verwerfen. Diese Unterscheidung zwischen geraden und ungeraden Zahlen lässt sich folgendermaßen umsetzen: 
- 
- 
-{{ :faecher:informatik:oberstufe:automaten:lepro:erstellung2:gerade02.png?600 |}} 
- 
-Jetzt muss noch der Endzustand richtig gesetzt und der Startzustand markiert werden. Der fertige Automat sieht dann folgendermaßen aus: 
- 
-{{ :faecher:informatik:oberstufe:automaten:lepro:erstellung2:gerade01.png?600 |}} 
- 
-===== Aufgabe ===== 
- 
-Entwirf nun selber einen Automaten, der als Eingabe Zahlen mit drei Stellen übergeben 
-bekommt und der alle Zahlen, die echt kleiner als 40 (also 040) sind, akzeptiert! 
- 
-Erstelle diesen Automaten zunächst mit Papier und Bleistift, übertrage ihn dann in JFLAP und teste ihn! 
- 
-====== Die Sprache eines Automaten ====== 
- 
-Zu jedem Automaten lässt sich eine Menge von Wörtern finden, die dieser Automat akzeptiert. Diese 
-Menge wird **Sprache** des Automaten genannt. Man sagt auch: Der Automat erkennt diese Sprache. 
- 
-Ein Wort ist eine Zeichenkette, die aus beliebigen Zeichen des Eingabealphabets bestehen kann. Wörter können zum Beispiel 
-so aussehen: 
- 
-  * Baum 
-  * abbc 
-  * 011BK5 
- 
-Betrachte noch einmal den Automaten aus dem ersten Beispiel dieses Kapitels. Dieser Automat akzeptiert alle geraden Zahlen mit vier Stellen. Man kann diese Zahlen mit der folgenden Menge beschreiben: {0000, 0002, 0004, ..., 9996, 9998}. Diese Menge ist also die Sprache, die dieser Automat erkennt. 
- 
-<WRAP center round important 60%> 
- 
-**Wort:** Zeichenkette, die aus beliebigen Zeichen des Eingabealphabets  besteht. 
-**Sprache eines Automaten:** die Menge von Wörtern, die der Automat akzeptiert.  
- 
-Man sagt, der Automat erkennt diese Sprache. 
-</WRAP> 
- 
-===== Beispiel ===== 
- 
- 
-Betrachte noch ein weiteres Beispiel eines Automaten mit dem Eingabealphabet ''{a,b,c}'': 
- 
-{{ :faecher:informatik:oberstufe:automaten:lepro:erstellung2:bsp1.png |}} 
- 
-Dieser Automat akzeptiert alle Wörter, die mit a anfangen, mit a aufhören und in deren Mitte keine 
-weiteren a’s vorkommen, sondern nur beliebig viele b’s und c’s. Er erkennt also die Sprache, die aus 
-der Menge der oben beschriebenen Wörter besteht. 
  • faecher/informatik/oberstufe/automaten/lepro/erstellung2/start.1600875618.txt.gz
  • Zuletzt geändert: 23.09.2020 17:40
  • von sbel