# Scanner-Funktion für ein Wort # True, wenn das Wort in der Sprache liegt def scan_word(state, word): # Rekursionsabbruch wenn Wort leer (Länge = 0) if len(word) == 0: # Akzeptiert, wenn Automat in Endzustand, z.B.: return state == 1 or state == 3 char = word[0] # Ersten Buchstaben ist die Eingabe word = word[1:] # Ersten Buchstaben vom Restwort abtrennen # Übergangsfunktion if state == 0: if char in "0123456789": return scan_word(0,word) elif char == 0: return scan_word(1,word) if state == 1: if char == 0: return scan_word(2,word) # Übergänge # siehe nea_abacc.py für ein Beispiel # Kein Übergang möglich, Wort nicht akzeptiert return False # Programmstart if __name__ == "__main__": word = input("Bitte ein Wort eingeben: ") accepted = scan_word(0, word) if accepted: print(f"Das Wort '{word}' gehört zur Sprache") else: print(f"Das Wort '{word}' gehört nicht zur Sprache")