Einzelnen Beitrag anzeigen

Benutzerbild von Uwe Raabe
Uwe Raabe
Online

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.360 Beiträge
 
Delphi 12 Athens
 
#5

Re: "Lego Logo für Arme" - Brauche Hilfe

  Alt 21. Okt 2008, 18:03
Na dann...

Die Methode Execute bearbeitet den übergebenen String und "frisst" sozusagen alle Zeichen, mit denen sie etwas anfangen kann. Wenn sie die Befehlssequenz vollständig abarbeiten kann, ist S hinterher leer.

Innerhalb der Methode wird zunächst das erste Zeichen untersucht und entsprechend verzweigt. Bei den V- und R-Befehlen wird der anschließende Zahlenwert gelesen (auch GetZahl frisst die Zeichen, die es liest) und der Befehl direkt ausgeführt. Im Falle einer Wiederholung lesen wir auch die folgende Zahl und löschen die folgende öffnende Klammer. Dann merken wir uns den aktuellen Inhalt der restlichen Befehlssequenz und rufen in einer Schleife das Execute immer wieder mit dem gespeicherten Wert rekursiv auf. Die schließende Klammer in der Case-Anweisung sorgt für den notwendigen Rücksprung aus der Rekursion (bricht die while-Schleife ab).

Diese Lösung ist rein pragmatisch auf die geschilderte Aufgabe bezogen und erhebt keinen Anspruch auf didaktische Brauchbarkeit für das Lernen der Theoretischen Informatik. Die übergeordnete Routine fährt dann mit dem Reststring fort.
Uwe Raabe
  Mit Zitat antworten Zitat