Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.89/9: Рейтинг темы: голосов - 9, средняя оценка - 4.89
 Аватар для goradon
2 / 2 / 1
Регистрация: 30.12.2013
Сообщений: 72

Польская инверсная нотация

31.03.2014, 12:22. Показов 1867. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
помогите пожалуста зделать !!! уже ниделю сижу никак не могу зделать ((
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
31.03.2014, 12:22
Ответы с готовыми решениями:

Польская инверсная запись числа С++
Подскажите, пожалуйста,что это такое-Польская инверсная запись)

польская инверсная запись. Помогите с алгоритмом.
Не знаю как организовать алгоритм польской инверсной записи на С++. Если кто-то знает помогите пожалуйста.

Программа построения ПОЛИЗ(польская инверсная запись)
Здравствуйте, ув. программисты, помогите написать программу построения польской имперсной записи. Задание на фото

3
 Аватар для igorrr37
2878 / 2025 / 992
Регистрация: 21.12.2010
Сообщений: 3,779
Записей в блоге: 9
31.03.2014, 13:13
Вычисление текстовой формулы
0
Мой лучший друг-отладчик!
 Аватар для ZaMaZaN4iK
167 / 167 / 30
Регистрация: 24.06.2012
Сообщений: 662
Записей в блоге: 5
31.03.2014, 16:27
вот я когда-то писал код для такого простенького калькулятора.Может поможет:
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
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
#include <iostream>
#include <vector>
#include <string>
#include <cmath>
#include <cctype>
 
using namespace std;
 
string s;
int i,size;
vector <int> digit;
vector<char> op;
 
bool prav(char op)
{
    return op=='^' ? true : false;
}
 
bool is_op(char c)
{
    return c=='+' || c=='-' || c=='*' || c=='/' || c=='%' || c=='^';
}
 
bool is_unary()
{
    return i==0 || is_op(s[i-1]) || s[i-1] == '(';
}
 
int priority(char op)
{
    if(op<0)
        return 4;
    else
        return op=='+' || op=='-' ? 1 :
               op=='*' || op=='/' || op=='%' ? 2 :
               op=='^' ? 3 : -1; 
}
 
void process_op(char op)
{
    if(op<0)
    {
        int l=digit.back();
        digit.pop_back();
        switch(-op)
        {
            case '+': digit.push_back(l); break;
            case '-': digit.push_back(-l); break;
        }
    }
    else
    {
        int r=digit.back();
        digit.pop_back();
        int l=digit.back();
        digit.pop_back();
        switch(op)
        {
            case '+':digit.push_back(l+r);break;
            case '-':digit.push_back(l-r);break;
            case '*':digit.push_back(l*r);break;
            case '/':digit.push_back(l/r);break;
            case '%':digit.push_back(l%r);break;
            case '^':digit.push_back(int(pow(float(l),float(r))));break;
        }
    }
}
 
int calc()
{
    size=s.length();
    for(i=0;i<size;++i)
    {
        if(s[i] == '(')
            op.push_back('(');
        else if(s[i] == ')')
        {
            while(!op.empty() && op.back() != '(')
            {
                process_op(op.back());
                op.pop_back();
            }
            op.pop_back();
        }
        else if(is_op(s[i]))
        {
            char curop=s[i];
            if(is_unary())
                curop=-curop;
            while(!op.empty() && (!prav(op.back()) && curop >= 0 && priority(op.back()) >= priority(curop) || prav(op.back()) && priority(op.back()) > priority(curop) ))
            {
                process_op(op.back());
                op.pop_back();
            }
            op.push_back(curop);
        }
        else if(isdigit(s[i]))
        {
            string operand;
            while(i<size && isdigit(s[i]))
            {
                operand+=s[i];
                ++i;
            }
            --i;
            digit.push_back(atoi(operand.c_str()));
        }
    }
    while(!op.empty())
    {
        process_op(op.back());
        op.pop_back();
    }
    return digit.back();
}
 
 
 
int main()
{
    cin>>s;
    cout<<calc()<<endl;
    system("pause");
}
1
 Аватар для goradon
2 / 2 / 1
Регистрация: 30.12.2013
Сообщений: 72
31.03.2014, 21:39  [ТС]
ZaMaZaN4iK, можно както по проще а то мне нада здать прогу а там то что мы ещо не учили(векторы и стринги)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
31.03.2014, 21:39
Помогаю со студенческими работами здесь

Обратная Польская Нотация
Пытался реализовать ОПН....ничего не вышло,обращаюсь за помощью: в чем ошибка(и)? #include &lt;iostream&gt; using namespace std; ...

Обратная польская нотация
Как имея вид выражения в записи обратной польской нотации правильно расставить скобки?

Обратная польская нотация через структуру
есть такая структура, как через нее сделать ОПН? /*ФУНКЦИЯ ДОБАВЛЕНИЯ ЭЛЕМЕНТА В СТЕК*/ void push(STACK *&amp;Top, int nValue) { ...

Нотация указателей
Преподователь попросил применить нотацию указателей вместо нотации массивов, помогите пожалуйста. Вот мой код #include...

Нотация O большое
Здорова! Есть задачка: &quot;Изучите О() нотацию. Приведите реалистичный пример, в котором получается, что О(N*N) быстрее, чем О(N) для...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Программа принимает математическое выражение в виде строки и выдаёт его производную в виде строки и вычисляет значение производной при заданном х Логарифм записывается как: (x-2)log(x^2+2) -. . .
Камера 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. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru