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