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

Неверный перевод в постфиксную форму

26.12.2016, 21:31. Показов 1022. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Реализация алгоритма перевода выражения в постфиксную форму и последующего вычисления. Проблема в том, что когда после скобок в выражении есть ещё какой-либо оператор, то программа сначала обрабатывает его, а потом уже операторы до скобок вне зависимости от приоритета операции. Например, выражение a-(b-c)-d переводится в такую форму: abc-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
void TPostfix::ToStack(TStack<string> &stack, string &str) //стек операций
{
    if (str[0] == '(')
    {
        stack.PutIn(str);
        return;
    }
    if (stack.IsEmpty() == 1)
    {
        stack.PutIn(str);
        return;
    }
    string LastOp = stack.GetValue();
    if (TheTable(str, 1) <= TheTable(LastOp, 1))
    {
        while (TheTable(str, 1) <= TheTable(LastOp, 1))
        {
            if (LastOp[0] == '(')
                return;
            postfix = postfix + LastOp + " ";
            stack.PutOut();
            if (!stack.IsEmpty())
                LastOp = stack.GetValue();
            else
            {
                break;
            }
        }
        stack.PutIn(str);
    }
    else
    {
        stack.PutIn(str);
        return;
    }
}
 
void TPostfix::ToPostfix()
{
    TStack<string> stack;
    string str, tmp;
    for (int i = 0; i < infix.length(); i++)
    {
        tmp = infix[i];
        if (TheTable(str, 0) == 1)
        {
            ToStack(stack, str);
            str.clear();
        }
        if (TheTable(tmp, 0) == 1)
        {
            if (str.length() != 0)
            {
                ToOpTable(str);
                postfix = postfix + str + " ";
                str.clear();
            }
            ToStack(stack, tmp);
        }
        else
            str = str + tmp;
        tmp.clear();
    }
    if (str.length() != 0)
    {
        if (TheTable(str, 0) == 1)
            throw("Invalid string");
        else
        {
            ToOpTable(str);
            postfix = postfix + str + " ";
        }
    }
     while (!stack.IsEmpty())
    {
        if (stack.GetValue()[0] == '(')
        {
            stack.PutOut();
            continue;
        }
        postfix = postfix + stack.PutOut() + " ";
    }
}
}


Вот метод TheTable:
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
int TPostfix::TheTable(const string &str, int IsNeed) {
    /* Таблица операций
    IsNeed =    0 - является ли переименной, 1 - приоритет    */
    if (str == "")
        return 0;
 
    string TOperations[OPER_IN_ALL]; //операции
    TOperations[0] = '+';
    TOperations[1] = '-';
    TOperations[2] = '*';
    TOperations[3] = '/';
    TOperations[4] = '(';
    TOperations[5] = ')';
    TOperations[6] = "sin";
    TOperations[7] = "cos";
    TOperations[8] = "tg";
    TOperations[9] = "ctg";
    TOperations[10] = "sqrt";
 
    int TPriority[OPER_IN_ALL];     //приоритет
    TPriority[0] = 1;
    TPriority[1] = 1;
    TPriority[2] = 2;
    TPriority[3] = 2;
    TPriority[4] = 0;
    TPriority[5] = -1;
    TPriority[6] = 3;
    TPriority[7] = 3;
    TPriority[8] = 3;
    TPriority[9] = 3;
    TPriority[10] = 3;
 
    switch (IsNeed)
    {
    case 0:
        for (int i = 0; i < OPER_IN_ALL; i++)
            if (str.compare(TOperations[i]) == 0)
                return 1;
        return 0;
        break;
    case 1:
        for (int i = 0; i < OPER_IN_ALL; i++)
            if (str.compare(TOperations[i]) == 0)
                return TPriority[i];
        return -1;          //не является операцией
        break;
    default:
        throw("Invalid second variable in the function TheTable"); //assert???
        break;
    }
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
26.12.2016, 21:31
Ответы с готовыми решениями:

Преобразование в постфиксную форму
всем привет,нужна помощь с переводом из инфиксной формы в постфиксную форму.Есть наработки ,но работают они криво,помогите.из этого...

Преобразовать выражение в постфиксную форму
Преобразовать выражение, составленное из цифр и знаков арифметических операций (+,-,*,/) в постфиксную форму. В постфиксной форме сначала...

Перевод из инфиксной в постфиксную запись
Суть моей программы: перевод из инфиксной в постфиксную запись. Но проблема в том, что функция типа string не возвращает значение. В чём...

2
Вездепух
Эксперт CЭксперт С++
 Аватар для TheCalligrapher
12935 / 6802 / 1821
Регистрация: 18.10.2014
Сообщений: 17,214
26.12.2016, 21:44
Цитата Сообщение от Leto-chan Посмотреть сообщение
Реализация алгоритма перевода выражения в постфиксную форму и последующего вычисления.
Ну а если написать просто a-b-c, то что получится в результате?
0
0 / 0 / 0
Регистрация: 26.12.2016
Сообщений: 2
26.12.2016, 21:50  [ТС]
Сложение, умножение, вычитание, деление, простейшие тригонометрические операции, квадрат. Необходимо перевести выражение из инфиксной в постфиксную форму и вычислить по постфиксной форме результат

Добавлено через 1 минуту
TheCalligrapher, a b - c -
Там именно что со скобками беда, но как её исправить, я не знаю(
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
26.12.2016, 21:50
Помогаю со студенческими работами здесь

Перевод в постфиксную нотацию
Есть функция для перевода выражения в постфиксную нотацию. void postfix::convertToPostfix(char infix, char postfix) { int i=0, j=0; ...

Перевод выражения из инфиксной в постфиксную форму
Перевести выражение из инфиксной в постфиксную форму. Вот мой код. Почему то на некоторых примерах при выводе ответа несколько раз пищит и...

Перевод инфиксного выражения в постфиксную форму
Всем привет! Ребят нужна ваша помощь! С использованием стеков разработать программу перевода инфиксного выражения в постфиксную форму. В...

Перевод арифметического выражения из инфиксной форму в постфиксную
Помогите написать код, попытки были но неудачные . polsk=raw_input(&quot;vvedi polskyy &quot;) #infix or postfix in input??? not clear ...

Перевод из инфиксной в постфиксную
ПОМОГИТЕ ПОЖАААЛУЙСТА!!! НУЖНА ПРОГРАММА ПЕРЕВОД ИЗ ИНФИКСНОЙ В ПОСТФИКСНУЮ ФОРМУ ( ГДЕ САМО ВЫРАЖЕНИЕ ВВОДИТСЯ С КЛАВИАТУРЫ ) ...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru