Версия от 13:28, 9 февраля 2024; EducationBot(обсуждение | вклад)(Новая страница: «{{Английская Википедия/Панель перехода}} {{Short description|Binary tree representing a mathematical expression}} A '''binary expression tree''' is a specific kind of a binary tree used to represent expressions. Two common types of expressions that a binary expression tree can represent are algebraic<ref name="brpreiss">{{cite web |url=http://www.brpreiss.com/books/opus5/html/page264.html|...»)
(разн.) ← Предыдущая версия | Текущая версия (разн.) | Следующая версия → (разн.)
Like any binary tree, each node of a binary expression tree has zero, one, or two children. This restricted structure simplifies the processing of expression trees.
The input in postfix notation is: a b + c d e + * *
Since the first two symbols are operands, one-node trees are created and pointers to them are pushed onto a stack. For convenience the stack will grow from left to right.
The next symbol is a '+'. It pops the two pointers to the trees, a new tree is formed, and a pointer to it is pushed onto the stack.
Next, c, d, and e are read. A one-node tree is created for each and a pointer to the corresponding tree is pushed onto the stack.
Continuing, a '+' is read, and it merges the last two trees.
Now, a '*' is read. The last two tree pointers are popped and a new tree is formed with a '*' as the root.
Finally, the last symbol is read. The two trees are merged and a pointer to the final tree remains on the stack.[2]
Boolean expressions are represented very similarly to algebraic expressions, the only difference being the specific values and operators used. Boolean expressions use true and false as constant values, and the operators include <math>\land</math> (AND), <math>\lor</math> (OR), <math>\neg</math> (NOT).