Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.95/40: Рейтинг темы: голосов - 40, средняя оценка - 4.95
0 / 0 / 0
Регистрация: 22.01.2017
Сообщений: 18

Построение дерева выражения

10.06.2017, 11:05. Показов 7788. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Мне нужно построить дерево выражения вида (а*(в+с))/d. Написал код.
Что не так?

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
#include <iostream>
#include <string>
#include <windows.h>
#include <vector>
#include <iomanip>
 
using namespace std;
 
struct Tree {
    string field;
    Tree* left;
    Tree* right;
};
 
string input();
Tree* TreeBuild(string, int);
void showTree(Tree*, int);
Tree* add_right(Tree*);
Tree* add_left(Tree*);
 
 
int main() {
    SetConsoleOutputCP(1251);
    string curr = input();
    int size = curr.length();
    Tree* root = TreeBuild(curr, size);
    showTree(root, 0);
    system("pause");
    return 0;
}
 
string input() {
    string str;
    cout << "Введіть вираз: ";
    cin >> str;
    return str;
}
 
Tree* TreeBuild(string str, int size) {
    Tree* tree;
    vector<Tree*> arr;
    arr.push_back(tree);
    for (int i = 0; i  < size; i++)
        switch (str[i]){
        case '(':
            tree = add_left(tree);
            tree->field = "";
            arr.push_back(tree);
            break;
        case '*' || '-' || '+' || '/':
            tree->field = str[i];
            arr.push_back(tree);
            tree = add_right(tree);
            tree->field = "";
            break;
        case ')':
            tree = arr.back();
            arr.pop_back();
            break;
        default:
            tree->field = str[i];
            tree = arr.back();
            arr.pop_back();
            break;
        }
    return tree;
}
 
void showTree(Tree* p, int indent)
{
    if (p != NULL) {
        if (p->right)
            showTree(p->right, indent + 4);
        if (indent)
            cout << setw(indent) << ' ';
        if (p->right)
            cout << " /\n" << setw(indent) << ' ';
        cout << p->field << "\n ";
        if (p->left) {
            cout << setw(indent) << ' ' << " \\\n";
            showTree(p->left, indent + 4);
        }
    }
}
 
Tree* add_left(Tree *tree) {
    if (tree == NULL)
    {
        tree = new Tree;
        tree->field = "";
        tree->left = NULL;
        tree->right = NULL;
    }else
        tree->left = add_left(tree->left);
    return tree;
}
 
Tree* add_right(Tree *tree) {
    if (tree == NULL)
    {
        tree = new Tree;
        tree->field = "";
        tree->left = NULL;
        tree->right = NULL;
    }else
        tree->right = add_right(tree->right);
    return tree;
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
10.06.2017, 11:05
Ответы с готовыми решениями:

Построение дерева инфиксного скобочного выражения
Лабораторная: построить и вывести дерево инфиксного скобочного выражения. Что не так? В CodeBlocks вывод &quot;Segmentation fault&quot;...

Построение В*-дерева
Задание: Построение B* дерева, добавление вершин и балансировка в случае необходимости. подскажите источники где можно взять код, или...

Построение дерева каталогов
Уважаемые форумчане, подскажите пожалуйста, как на с++ реализовать задание: Построение дерева каталогов

2
 Аватар для Olej
322 / 170 / 24
Регистрация: 25.03.2012
Сообщений: 712
10.06.2017, 11:49
Цитата Сообщение от dimadima2 Посмотреть сообщение
Что не так?
Всё!

Для разбора любого скобочного выражения вам нужно 1 раз написать преобразование выражения в постфиксную (обратную польскую) запись ... которое целиком занимает места меньше, чем ваш код.
См. обратная польская запись - там есть готовый код.
1
Комп_Оратор)
Эксперт по математике/физике
 Аватар для IGPIGP
9006 / 4707 / 630
Регистрация: 04.12.2011
Сообщений: 14,003
Записей в блоге: 16
10.06.2017, 12:16
Цитата Сообщение от Olej Посмотреть сообщение
Всё!
Похоже на то.
dimadima2, стек или рекурсия и правда легче. Может не стоит сразу дерево выражений строить?
Для дерева, любой нод должен (или может?) быть токеном. То есть неделимой лексической частичкой разбиения (парсинга строки задающей выражение). Затем, можно реализовать порождение узла результата (числового токена, вне зависимости реализуете ли Вы переменные или нет) любыми операциями старшего приоритета, будь-то пара скобок, функция или */^. Демонстрация такого подхода относительна громоздка. И мало что даст. Когда Вы почувствуете, что можете такое написать, - напишете.
И к бинарным деревьям это не относится. Можно в ноде хранить список указателей на нод. Удобно.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
10.06.2017, 12:16
Помогаю со студенческими работами здесь

Построение бинарного дерева
Доброй ночи! Пятые сутки не могу разобрать реализацию алгоритма на С++ Console Wizzard! Что такое бинарное дерево я знаю, даже разобрал...

Построение бинарного дерева
Написать программу построения бинарного дерева с помощью связных структур и поиска в дереве при симметричном порядке обхода его. Если...

Рекурсивное построение дерева
Здравствуйте ! Как построить рекурсивным образом дерево?

Построение дерева Пифагора
Дерево Пифагора Пифагор, доказывая свою знаменитую теорему, построил фигуру, где на сторонах прямоугольного треугольника расположены...

Построение бинарного дерева из строки
Доброго времени суток, уважаемые. Хотел бы спросить у вас спросить совета относительно реализации следующей проблемы: Задано...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru