0 / 0 / 0
Регистрация: 11.07.2017
Сообщений: 9
1

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

14.06.2018, 11:43. Показов 1779. Ответов 6
Метки нет (Все метки)

Есть арифметическое выражение, которое содержит знаки операций +,-, *, /
Нужно используя стек вывести знаки операций в обратно порядке
Помогите пожалуйста, не смог разобраться как это сделать)
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
14.06.2018, 11:43
Ответы с готовыми решениями:

Используя стек вывести числа введенные пользователем в обратном порядке элемент стека – число
помогите плиз решить ..Используя стек вывести числа введенные пользователем в обратном порядке...

Используя стек ,переписать строку посимвольно в обратном порядке
Используя стек ,переписать строку посимвольно в обратном порядке!!!!!!!!!!!

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

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

6
183 / 169 / 92
Регистрация: 13.06.2018
Сообщений: 701
14.06.2018, 12:06 2
и выражение есть?

Добавлено через 17 минут
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
struct sign
{
    char sg;
    sign* next;
};
void push(sign* &top,char ch)
{
    sign* next=top;
    top=new sign();
    top->sg=ch;
    top->next=next;
}
char pop(sign* &top)
{
    sign* old=top;
    top=top->next;
    char sg=old->sg;
    delete old;
    return sg;
}
void main(int argc,char **argv)
{
    string s="1+2-3*4/5";
    sign* top=0;    
    for(int i=0; i<s.length(); i++)
        if(s[i]=='+' || s[i]=='-' || s[i]=='*' || s[i]=='/')
            push(top,s[i]);
    while(top)
        cout<<pop(top)<<" ";
    cout<<endl;
    system("pause");
}
1
0 / 0 / 0
Регистрация: 11.07.2017
Сообщений: 9
14.06.2018, 15:25  [ТС] 3
Цитата Сообщение от Biger18 Посмотреть сообщение
и выражение есть?
Задание звучит так:
Дано арифметическое выражение, содержащее знаки операций: +, -, *, /. Используя стек, вывести знаки операций в обратном порядке.

Добавлено через 2 часа 49 минут

Добавлено через 2 минуты
Не подскажете, как сделать, что бы знаки выражений менялись именно в самом выражении? А не отдельно
0
183 / 169 / 92
Регистрация: 13.06.2018
Сообщений: 701
14.06.2018, 15:26 4
потому и спросил что есть и что нужно
0
473 / 425 / 290
Регистрация: 10.03.2015
Сообщений: 1,782
14.06.2018, 15:32 5
Цитата Сообщение от Mon1k66 Посмотреть сообщение
Используя стек, вывести знаки операций в обратном порядке.
Пробегаешься по выражению и пушишь все знаки операций в стек.
В стеке они уже будут в обратном порядке.
Попаешь стек пока не пуст, получишь ряд знаков операций в обратном порядке
0
183 / 169 / 92
Регистрация: 13.06.2018
Сообщений: 701
14.06.2018, 15:41 6
C++
1
2
3
4
5
//вместо while
    for(int i=0; top && i<s.length(); i++)
        if(s[i]=='+' || s[i]=='-' || s[i]=='*' || s[i]=='/')
            s[i]=pop(top);
    cout<<s<<endl;
1
473 / 425 / 290
Регистрация: 10.03.2015
Сообщений: 1,782
14.06.2018, 18:20 7
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
#include <iostream>
#include <stack>
 
using namespace std;
 
int main()
{
    stack<char> signs;
    string expr = "1+2-3*4/5";
    for (int i=0; i<expr.length(); i++)
    {
        if (!isdigit(expr[i]))
            signs.push(expr[i]);
    }
    
    int pos = 0;
    while (!signs.empty())
    {
        cout << signs.top();
        while (isdigit(expr[pos])) pos++;
        expr[pos] = signs.top();
        pos++;
        signs.pop();
    }
    cout << endl << expr << endl;
    return 0;
}
Добавлено через 2 часа 36 минут
Единственное, возможны проблемы при вещественных числах) но это можно поправить)
1
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
14.06.2018, 18:20
Помогаю со студенческими работами здесь

Как описать стек в котором будут лежать знаки орифметич операций?
нужно именно описание самой структуры и методы для неё, пуш и поп

Ввести число, занести его цифры в стек. Вывести в число, у которого цифры идут в обратном порядке
Ввести число, занести его цифры в стек. Вывести в число, у которого цифры идут в обратном порядке.

Используя стек вывести числа введенные пользователем в обратном порядке.
помогите плиз решить задачу......Используя стек вывести числа введенные пользователем в обратном...

Используя стек переписать элементы в обратном порядке
Здравствуйте! Помогите пожалуйста со следующим: В Edit записывается любая последовательность...


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2023, CyberForum.ru