Лучшие помощники
- Megamozg 2205 б
- Matalya1 1800 б
- DevAdmin 1720 б
- arkasha_bortnikov 895 б
- Dwayne_Johnson 860 б
2 апреля 2023 07:36
420
Постройте дерево, соответствующее арифметическому выражению. Запишите это выражения в префиксной и постфиксной формах:(a+b)*(c+2*d)
(2*a-3*d)*c+2*b
3*a-(2*b+c)*d
1
ответ
Деревья строятся просто: добавляем узел – операцию, которая выполняется последней, и к ней два потомка – аргументы этой операции. Например, для выражения a + b операцией будет "+", а аргументами – a и b. Затем в таком же виде представляем аргументы этой операции, пока все аргументы не будут содержать выражений. Построенные деревья во вложении.
Префиксная форма записи заключается в том, что сначала записывается операция, потом префиксная запись её первого аргумента, потом второго аргумента. Это соответствует обходу дерева сверху вниз и слева направо, записываем, что сверху, потом идем вниз. Вот что получится в итоге:
а) * + a b + c * 2 d
б) + * - * 2 a * 3 d c * 2 b
в) - * 3 a * + * 2 b c d
В постфиксной записи, наоборот, записываются сначала аргументы, потом операция. Это соответствует обходу дерева снизу-вверх.
а) a b + c 2 d * + *
б) 2 a * 3 d * - c * 2 b * +
в) 3 a * 2 b * c + d * -
Префиксная форма записи заключается в том, что сначала записывается операция, потом префиксная запись её первого аргумента, потом второго аргумента. Это соответствует обходу дерева сверху вниз и слева направо, записываем, что сверху, потом идем вниз. Вот что получится в итоге:
а) * + a b + c * 2 d
б) + * - * 2 a * 3 d c * 2 b
в) - * 3 a * + * 2 b c d
В постфиксной записи, наоборот, записываются сначала аргументы, потом операция. Это соответствует обходу дерева снизу-вверх.
а) a b + c 2 d * + *
б) 2 a * 3 d * - c * 2 b * +
в) 3 a * 2 b * c + d * -

0
·
Хороший ответ
4 апреля 2023 07:36
Остались вопросы?
Еще вопросы по категории Информатика
Переведите число 150 из восьмиричной системы счисления в десятичную систему счисления....
Требуется заполнить массив длиной 5 случайными числами от 100 до 200. from random import randint A = [ ...(100,200) for x in range(5)]...
Определите значения переменных a, b и с после выполнения программного кода: s='КАЛИНА' a=s.cоunt('А') b=s.find('Л') c=s.replаce('К','М'...
Сколько существует различных последовательностей из символов плюс и минус длиной 6 символов...
Как формируется индивидуальное информационное пространство?...