Форум программистов, компьютерный форум CyberForum.ru

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

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

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

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

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

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

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

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

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

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

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

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

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

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

Польская запись - C++
Здравствуйте, у меня возникли некоторые проблемы с данной задачей(если сказать точнее, то я ее вообще не понял): Дано выражение...

польская запись - C++
как написать программу,которая математическое выражение переводит из обычного запися в польскую запись с помощью стека?...

Префиксная польская запись - C++
Здравствуйте, очень нужна помощь умных людей( Задача: Написать код для преобразования инфиксной записи выражения в префиксную, вообще нет...


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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
igorrr37
1641 / 1269 / 133
Регистрация: 21.12.2010
Сообщений: 1,932
Записей в блоге: 7
31.03.2014, 13:13     Польская инверсная нотация #2
Вычисление текстовой формулы
ZaMaZaN4iK
Мой лучший друг-отладчик!
163 / 163 / 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");
}
goradon
0 / 0 / 0
Регистрация: 30.12.2013
Сообщений: 71
31.03.2014, 21:39  [ТС]     Польская инверсная нотация #4
ZaMaZaN4iK, можно както по проще а то мне нада здать прогу а там то что мы ещо не учили(векторы и стринги)
Yandex
Объявления
31.03.2014, 21:39     Польская инверсная нотация
Ответ Создать тему
Опции темы

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