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

Как описать стек в котором будут лежать знаки орифметич операций? - C++

Восстановить пароль Регистрация
 
kondusov
2 / 2 / 0
Регистрация: 01.06.2013
Сообщений: 152
07.11.2013, 12:40     Как описать стек в котором будут лежать знаки орифметич операций? #1
нужно именно описание самой структуры и методы для неё, пуш и поп
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
07.11.2013, 12:40     Как описать стек в котором будут лежать знаки орифметич операций?
Посмотрите здесь:

Класс, реализующий стек. Перегрузка операций взятия и извлечения элемента. C++
C++ Расставить знаки арифметических операций так, чтобы сошелся результат
C++ Программа с рекурсивной функцией (расставляет между заданными шестью цифрами знаки операций)
C++ описать структуру, создать класс, в котором описать 3 поля: два простых типа и массив структур. Создать в классе 4 функции работы с массивом структур
C++ в консоли редактировать знаки операций в примере
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Raali
572 / 276 / 12
Регистрация: 06.07.2013
Сообщений: 917
Завершенные тесты: 1
07.11.2013, 12:45     Как описать стек в котором будут лежать знаки орифметич операций? #2
Цитата Сообщение от kondusov Посмотреть сообщение
нужно именно описание самой структуры и методы для неё, пуш и поп
C++
1
2
3
4
5
6
7
8
struct stack
{
char item;
stack* last;
stack* prev;
char pop();
void push(char);
};
kondusov
2 / 2 / 0
Регистрация: 01.06.2013
Сообщений: 152
07.11.2013, 13:19  [ТС]     Как описать стек в котором будут лежать знаки орифметич операций? #3
пробую написать простенькую программу которая из инфиксной записи выражения сделает постфиксную
вывожу входную строку - всё ок.
вывожу выход - она пустая. почему так получается?

цифры используются и знаки
цифры беру от нуля до девяти(для простоты)
kol подсчтывать должна количество данных помещённых в стек


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
#include <iostream>
#include <string>
 using namespace std;
struct stek
{
    char d;
    struct stek *next; // указатель на следующий элемент списка (стека)
};
 
 
void push(stek* &next, int d)
{
    stek *pv = new stek;      // объявляем новую динамическую переменную типа stek
    pv->d = d;                // записываем  значение, которое помещается в стек
    pv->next = next;          // связываем новый элемент стека с предыдущим
    next = pv;                // новый элемент стека становится его вершиной
}
 
char pop(stek* &next)
{  
    char temp = next->d;     // извлекаем в переменную temp значение в вершине стека
    stek *pv = next;        // запоминаем указатель на вершину стека, чтобы затем
                            // освободить выделенную под него память
    next = next->next;      // вершиной становится предшествующий top элемент
    delete pv;              // освобождаем память, тем самым удалили вершину
    
    return temp;          // возвращаем значение, которое было в вершине
}
int kol;
int main()
{
    string s, otvet;
    stek*p=0;
 
 
getline(cin, s);
 
cout<<"\n vashe virazhenie v obi4noy zapisi :"<<s<<"\n";
for(int i=0;i<10;i++)
    {
        if ('s[i]'>'0'  &&  's[i]'<'10')
        otvet+=s[i];
            if ('s[i]'=='+' || 's[i]'=='-' ||'s[i]'=='*' || 's[i]'=='/'){
            push (p,s[i]);
            kol++;
        }}
for (int i=0;i<kol;i++){
    otvet+=pop(p);}
cout<<'\n'<<"POSTFIKS ---       "<<otvet;
return 0;
}
ZaMaZaN4iK
Мой лучший друг-отладчик!
 Аватар для ZaMaZaN4iK
163 / 163 / 9
Регистрация: 24.06.2012
Сообщений: 662
Записей в блоге: 5
Завершенные тесты: 1
07.11.2013, 15:54     Как описать стек в котором будут лежать знаки орифметич операций? #4
kondusov, есть замечательный метод Дейкстры по этому поводу. Ну и можете e-maxx.ru почитать - там статья про обратную польскую нотацию, в ней используется промежуточное преобразование из инфиксной в постфиксную
Yandex
Объявления
07.11.2013, 15:54     Как описать стек в котором будут лежать знаки орифметич операций?
Ответ Создать тему
Опции темы

Текущее время: 08:43. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru