Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.73/11: Рейтинг темы: голосов - 11, средняя оценка - 4.73
 Аватар для dicros
1 / 1 / 0
Регистрация: 24.04.2014
Сообщений: 66

Разбор арифметических выражений

25.06.2014, 00:24. Показов 2351. Ответов 7
Метки нет (Все метки)

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

(ch - '0')

где ch - это число от 0 до 9

Вот пример целиком:

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
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
#include <iostream>
#include <cstring>
using namespace std;
 
const int LEN = 80;
const int MAX = 40;
 
class Stack
{
private:
    char st[MAX];
    int top;
public:
    Stack(){top = 0;};     //конструктор
 
    void push(char var)
    {
        st[++top] = var;
    };
 
        char pop()
        {
            return st[top--];
        };
 
            int gettop()
            {
                return top;
            };
};
 
class express
{
private:
    Stack s;
    char* pStr;
    int len;
public:
    express(char* ptr)             //конструктор
    {
        pStr = ptr;
        len = strlen(pStr);
    };
 
    void parse()
    {
        char ch;
        char lastval;
        char lastop;
 
        for (int j = 0; j < len; j++)
        {
            ch = pStr[j];
 
            if (ch >= '0' && ch <= '9')
            {
                s.push(ch - '0');
            }
            else
            {
                if (ch == '+' || ch == '-' || ch == '*' || ch == '/')
                {
                    if (s.gettop() == 1)
                    {
                        s.push(ch);
                    }
                    else
                    {
                        lastval = s.pop();
                        lastop = s.pop();
 
                        if ((ch == '*' || ch == '/') && (lastop == '+' || lastop == '-'))
                        {
                            s.push(lastop);
                            s.push(lastval);
                        }
                        else
                        {
                            switch (lastop)
                            {
                                case '+': s.push(s.pop() + lastval); break;
                                case '-': s.push(s.pop() - lastval); break;
                                case '*': s.push(s.pop() * lastval); break;
                                case '/': s.push(s.pop() / lastval); break;
                                default: cout << "\nНеизвестный оператор"; exit(1);
                            };
                        }
 
                        s.push(ch);
                    }
                }
                else
                {
                    cout << "\nНеизвестный символ";
                    exit(1);
                }
 
            }
        }
 
    };
 
    int solve()
    {
        char lastval;
 
        while (s.gettop() > 1)
        {
            lastval = s.pop();
 
            switch (s.pop())
            {
                case '+': s.push(s.pop() + lastval); break;
                case '-': s.push(s.pop() - lastval); break;
                case '*': s.push(s.pop() * lastval); break;
                case '/': s.push(s.pop() / lastval); break;
                default:cout << "\nНеизвестный оператор"; exit(1);
            };
        }
 
        return int(s.pop());
    };
};
 
int main()
{
    setlocale(0, "Rus");
 
    char ans;
    char string[LEN];
 
    cout << "\nВведите арифметическое выражение в виде 2+3*4/3-2"
         << "\nЧисла должны быть из одной цифры"
         << "\nне используйте пробелы и скобки";
 
    do
    {
        cout << "\nВыражение: ";
        cin >> string;
        express* eptr = new express(string);
        eptr->parse();
        cout << "\nРезультат: " << eptr->solve();
        delete eptr;
        cout << "Еще одно выражение (д/н)?";
        cin >> ans;
    } while (ans=='д');
 
return 0;
};
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
25.06.2014, 00:24
Ответы с готовыми решениями:

Разбор арифметических выражений
Задача на указатели из учебника Р.Лафоре. если вкратце, то суть заключается в том, что мы вводим строку без пробелов и скобок(например,...

Решение арифметических выражений
Помогите, пожалуйста, составить программы...

Вычисление арифметических выражений
У меня есть пример к которому надо написать программу чтоб его посчитала. Так вот я ее сделал но ответы не совпадают #include...

7
2784 / 1937 / 570
Регистрация: 05.06.2014
Сообщений: 5,602
25.06.2014, 03:43
Здравствуйте друзья снова я к вам за помощью конечно вопрос может покажется банальным, но то ли время уже много и голова не соображает, то ли я тугой но ни как не могу понять смысла выражения.
В C++ символы это абсолютно тоже самое что их коды (можно вместо символа написать его код, компилятор скушает и не подавится). Соответственно, (ch - '0') вычитает из кода символа ch код символа '0'.
0
 Аватар для dicros
1 / 1 / 0
Регистрация: 24.04.2014
Сообщений: 66
25.06.2014, 21:23  [ТС]
Цитата Сообщение от Renji Посмотреть сообщение
В C++ символы это абсолютно тоже самое что их коды (можно вместо символа написать его код, компилятор скушает и не подавится). Соответственно, (ch - '0') вычитает из кода символа ch код символа '0'.
Вот коды:

48 -> 0
49 -> 1
50 -> 2
51 -> 3
52 -> 4
53 -> 5
54 -> 6
55 -> 7
56 -> 8
57 -> 9
Допустим у нас число 5 тогда в выражении (ch - '0') -> (53 - 48) = 5.

Вопрос тот же для чего это нужно если какое бы число не было от 0 до 9 все равно результат будет это же число зачем ноль то вычитать????
0
2784 / 1937 / 570
Регистрация: 05.06.2014
Сообщений: 5,602
25.06.2014, 21:30
Допустим у нас число 5 тогда в выражении (ch - '0') -> (53 - 48) = 5.
А вот символ '5' (в кавычках) и число 5 (без кавычек) - вещи разные. Хотя, в каком ни будь Перле в большинстве случаев действительно эквивалентны.
0
 Аватар для dicros
1 / 1 / 0
Регистрация: 24.04.2014
Сообщений: 66
25.06.2014, 21:34  [ТС]
Renji, так в чем же здесь суть объясни пожалуйста никак не могу понять, что в результате то получиться??
0
2784 / 1937 / 570
Регистрация: 05.06.2014
Сообщений: 5,602
25.06.2014, 21:36
Код символа (53) преобразуется в цифру (5).
0
 Аватар для dicros
1 / 1 / 0
Регистрация: 24.04.2014
Сообщений: 66
25.06.2014, 21:39  [ТС]
Renji, это я прекрасно понимаю я не могу понять зачем 0 то вычитать, ведь это не спроста. Потому что пробовал его убрать ответ совсем не правильный получается значит он на что то влияет и причем основательно.
0
2784 / 1937 / 570
Регистрация: 05.06.2014
Сообщений: 5,602
25.06.2014, 21:49
Renji, это я прекрасно понимаю я не могу понять зачем 0 то вычитать, ведь это не спроста.
Затем что 0 и '0' (обрати внимание на кавычки) два абсолютно разных числа.
Цифра => Цифра.
ЦифраЦифраЦифра => число ЦифраЦифраЦифра.
'Цифра' (в одинарных кавычках) => код символа соответствующего цифре. А вовсе не цифра.
"ЦифраЦифраЦифра" => массив кодов символов заканчивающийся нулем. Опять же, с числом ЦифраЦифраЦифра ничего общего не имеет.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
25.06.2014, 21:49
Помогаю со студенческими работами здесь

Распараллеливание арифметических выражений
Здравствуйте. Есть задача - распараллелить вычисление арифмитического выражения, подобное виду (a+b)+(c+(d+e+f))+h т.е....

Вычисление арифметических выражений
Здраствуйте. Меня волнует такой вопрос по С++ - вот я к примеру хочу вычислить какое-нибудь арифметическое выражение с переменными x, y, z....

Парсер арифметических выражений
Добрый вечер, пишу простенький парсер для разбора выражений, содержащих рациональные числа. Вот код: #include &lt;iostream&gt; ...

Табулирование арифметических выражений
Написать программу для вычисления табулированных значении функции y = f(x) на интервале от xn до xk с шагом дельта x. Предусмотреть ввод...

Парсер арифметических выражений
Пишу парсер мат. выражений. Столкнулся с проблемкой: как обозначить унарные операции + и - ? Есть мапа приоритетов: ...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru