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

Использование стека в преобразовании

15.06.2011, 21:26. Показов 844. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Наткнулся на одну проблему и нуждаюсь в помощи. задание следующее. Нужно преобразовать инфиксное выражение в постфиксное, используя стек.
то есть например из "4+(6-4)*9" нужно получить "4 6 4 - 9 *+" и вывести это на экран
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
15.06.2011, 21:26
Ответы с готовыми решениями:

Использование стека
Очереди, стеки В текстовом файле записано без ошибок логическое выражение следующего вида: <лог.выр.>::=true | false |...

Использование стека
Здравствуйте,помогите разобраться с задачей пожалуйста. Дана последовательность из n чисел,нужно напечатать только отрицательные числа из...

Использование стека STL
Прошу поддержки, дайте комментарии к коду по стекам.Код писал мой кореш,а я плохо врубаюсь в стеки #include <iostream> #include...

3
13 / 13 / 1
Регистрация: 20.07.2010
Сообщений: 43
16.06.2011, 03:49
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
#include <stdio.h>
#include <stdlib.h>
 
struct node {
    struct node * next;
    char value;
} *_top;
struct list {
    struct node * head;
};
 
void push(char value){
    struct node * node;
    node = (struct node*)malloc(sizeof(*node));
    if(_top != NULL) {
        node->next = _top;
        _top = node;
    }
    else{
        _top = node;
    }
    node->value = value;
    
}
void pop(){
    struct node * node;
    if(_top != NULL) {
        node = _top;
        _top = _top->next;
        free(node);
    }
}
char top(){
    if(_top != NULL)
        return (char)_top->value;
    else
        return 0;
}
 
 
int main(){
    int i=0,j=0;
    char exprassion[9] = {'4','+','(','6','-','4',')','*','9'};
    char result[9] ={0};
    for(i=0;i<9;++i){
        switch(exprassion[i]){
            case '+':
                if(top() != '*')
                    push('+');
                else {
                    result[j] = top();
                    pop();
                    push('+');
                    ++j;
                }
                break;
            case '-':
                if(top() != '*')
                    push('-');
                else {
                    result[j] = top();
                    pop();
                    push('-');
                    ++j;
                }
            break;
            case '*':
                push('*');
                break;
            case '(':
                push('(');
                break;
            case ')':
                while(top() != '(') {
                    result[j] = top();
                    pop();
                    ++j;
                }
                pop();
                break;
            default:
                result[j] = exprassion[i];
                ++j;            
        }
    }
    while(top() != 0) {
        result[j] = top();
        pop();
        ++j;
    }
    for(i=0;i<10;++i){
        printf("%c", result[i]);
    }
    
    
    return 0;
}
Держи)
Такая штука называется обратная польская запись)
1
Xarty
16.06.2011, 10:05
Цитата Сообщение от Ruu Посмотреть сообщение
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
#include <stdio.h>
#include <stdlib.h>
 
struct node {
    struct node * next;
    char value;
} *_top;
struct list {
    struct node * head;
};
 
void push(char value){
    struct node * node;
    node = (struct node*)malloc(sizeof(*node));
    if(_top != NULL) {
        node->next = _top;
        _top = node;
    }
    else{
        _top = node;
    }
    node->value = value;
    
}
void pop(){
    struct node * node;
    if(_top != NULL) {
        node = _top;
        _top = _top->next;
        free(node);
    }
}
char top(){
    if(_top != NULL)
        return (char)_top->value;
    else
        return 0;
}
 
 
int main(){
    int i=0,j=0;
    char exprassion[9] = {'4','+','(','6','-','4',')','*','9'};
    char result[9] ={0};
    for(i=0;i<9;++i){
        switch(exprassion[i]){
            case '+':
                if(top() != '*')
                    push('+');
                else {
                    result[j] = top();
                    pop();
                    push('+');
                    ++j;
                }
                break;
            case '-':
                if(top() != '*')
                    push('-');
                else {
                    result[j] = top();
                    pop();
                    push('-');
                    ++j;
                }
            break;
            case '*':
                push('*');
                break;
            case '(':
                push('(');
                break;
            case ')':
                while(top() != '(') {
                    result[j] = top();
                    pop();
                    ++j;
                }
                pop();
                break;
            default:
                result[j] = exprassion[i];
                ++j;            
        }
    }
    while(top() != 0) {
        result[j] = top();
        pop();
        ++j;
    }
    for(i=0;i<10;++i){
        printf("%c", result[i]);
    }
    
    
    return 0;
}
Держи)
Такая штука называется обратная польская запись)
благодарю, но это не совсем то, что было нужно. тут моя вина, я сразу не пояснил всё. в общем в задании нужно создать класс Stack, соответственно все важные переменные должны будут оказаться в privat`e и доступ к ним должны быть только через функции, объявленные в public`e.
и эта функция должна быть справедлива для любых вводимых значений, а не для конкретного примера как у тебя) то есть пользователь вводит любое выражение , содержащее любые цифры, стандартные операции (+, -, *, /, ^) и круглые скобки, в инфиксной форме, наша прога должна это выражение преобразоваться в постфиксную
13 / 13 / 1
Регистрация: 20.07.2010
Сообщений: 43
16.06.2011, 12:52
Xarty, я тебе показал как стек будет реализован на Cи.
На С++ можешь переписать сам, я думаю это не составит особого труда.
операция деления если на Си -- добавляешь еще один case в switch и все работает.

Добавлено через 2 часа 16 минут
Цитата Сообщение от Xarty Посмотреть сообщение
struct list {
struct node * head;
};
Эта структура не нужна, она не используется. Там указатель на узел стека уже есть -- _top.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
16.06.2011, 12:52
Помогаю со студенческими работами здесь

Реализация и использование стека
Господа, помогите разобраться со стеком. Хотя бы расскажите, как его правильно объявлять и заполнять. Я смотрел много всяких тем и сайтов,...

Интересная задача на использование стека
Здравствуйте, уважаемые форумчане! На этот раз решил немного поделиться недавно полученным опытом при решении одной несложной задачи. Само...

Использование стека для печати строки в обратной последовательности
нужно написать программу, которая вводит строку текста и использует объект стека для печати строки в обратной последовательности. очень...

Использование СТЕГАНОГРАФИИ посредством ретрансмиссии в протоколах стека TCP/IP.
Очень мало информации по использованию стеганографии в стеке TCP/ip, а софта тем более не встречал!!! В основном натыкаюсь на использование...

Использование this внутри map при преобразовании массива
Всем привет. Недавно начал изучать React на онлайн-курсах. И вот, задание: &quot;Создайте компонент Tabs, который выводил бы...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru