Einzelnen Beitrag anzeigen

Benutzerbild von Khabarakh
Khabarakh

Registriert seit: 18. Aug 2004
Ort: Brackenheim VS08 Pro
2.876 Beiträge
 
#9

Re: Suche Lösungsansatz zum Verbessern des Parsen von Funkti

  Alt 11. Apr 2009, 16:30
Zitat von SimStar001:
Ich habe irgendwie ein Problem damit zu verstehen, wie man eine Klasse definiert, in der dann alle Daten stecken, sprich die Einzelnen Nodes und Branches.
Eigentlich dachte ich, genau das vorgestellt zu haben .
Schau dir mal TBinOp, die Klasse für alle binären Operatoren wie +,-,*,/ an: Der Konstruktor nimmt zwei weitere TOps entgegen, das sind die mit diesem Binary-Node verknüpften Branches.
Um mal dein Beispiel 3*x^2-4 umzusetzen:
Delphi-Quellcode:
TBinOp(
  Kind = bokMinus,
  Left = TBinOp(
    Kind = bokMul,
    Left = TConstantOp(Value = 3),
    Right = TBinOp(
      Kind = bokPower,
      Left = TVariableOp(
        Var = TVar(Name = "x", Value = ...)
      ),
      Right = TConstantOp(Value = 2)
    ),
  ),
  Right = TConstantOp(Value = 4),
)
Habe mal zur Übersicht doch noch eine TConstantOp-Klasse eingeführt.
Wenn du das Zeile für Zeile durchgehst, sind wir übrigens bei der Polnischen Notation : - * 3 ^ x 2 4
Sebastian
Moderator in der EE
  Mit Zitat antworten Zitat