Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
goradon
0 / 0 / 0
Регистрация: 30.12.2013
Сообщений: 71
#1

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

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

помогите пожалуста зделать !!! уже ниделю сижу никак не могу зделать ((
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
31.03.2014, 12:22
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Польская инверсная нотация (C++):

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

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

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

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

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

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

3
igorrr37
1663 / 1291 / 143
Регистрация: 21.12.2010
Сообщений: 1,967
Записей в блоге: 9
31.03.2014, 13:13 #2
Вычисление текстовой формулы
0
ZaMaZaN4iK
Мой лучший друг-отладчик!
164 / 164 / 9
Регистрация: 24.06.2012
Сообщений: 662
Записей в блоге: 5
Завершенные тесты: 1
31.03.2014, 16:27 #3
вот я когда-то писал код для такого простенького калькулятора.Может поможет:
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
0 / 0 / 0
Регистрация: 30.12.2013
Сообщений: 71
31.03.2014, 21:39  [ТС] #4
ZaMaZaN4iK, можно както по проще а то мне нада здать прогу а там то что мы ещо не учили(векторы и стринги)
0
31.03.2014, 21:39
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
31.03.2014, 21:39
Привет! Вот еще темы с ответами:

Нотация указателей - C++
Преподователь попросил применить нотацию указателей вместо нотации массивов, помогите пожалуйста. Вот мой код #include &lt;iostream&gt; ...

Венгерская нотация. А что вы думаете? - C++
Уже который день задумываюсь о надобности использования префиксов. С одной стороны - очень полезно, с другой стороны при определенных...

Кто как обзывает переменные / типы в своём коде? (нотация) - C++
Не ради тролинга, а ради интереса и любопытства. Столько разных API и фрейворков, у всех свой стиль нотации, подстраиваться под...

Венгерская нотация, оно вообще надо? - C++
Вопрос в заголовке. Больше всего смущает префикс m_ для приватных членов класса, ни информативности на красоты, а печатать дольше. Общее...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.