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

Разбор выражений

25.05.2014, 15:17. Показов 2995. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Вывести значение целочисленного выражения, заданного в виде строки S. Выражение определяется следующим образом:
<выражение> ::= <терм> | <выражение>+<терм> |
<выражение>–<терм>
<терм> ::= <элемент> | <терм> * <элемент>
<элемент> ::= <цифра> | (<выражение>)

Кто-нибудь объясните, как выглядит в коде построение по такому принципу... Вообще не могу понять.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
25.05.2014, 15:17
Ответы с готовыми решениями:

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

Разбор математических выражений
Добрый день, нуждаюсь в вашей помощи. Написал код программы для решения определённого уравнения методом половинного деления. Необходимо...

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

9
88 / 69 / 19
Регистрация: 07.03.2011
Сообщений: 175
25.05.2014, 15:34
Копайте в сторону синтаксического анализа. Хороший пример с последовательным разбором и развитием мыслей есть в учебнике Страуструпа. Там рассматривается именно такие выражения.
0
0 / 0 / 0
Регистрация: 04.12.2013
Сообщений: 52
25.05.2014, 16:29  [ТС]
Чумаков Антон, я конкретно не могу поймать мысль, просто я могу вообще взять и сделать калькулятор и вычислить выражение, а для чего это :
<выражение> ::= <терм> | <выражение>+<терм> |
<выражение>–<терм>
<терм> ::= <элемент> | <терм> * <элемент>
<элемент> ::= <цифра> | (<выражение>)
я не могу понять..
0
88 / 69 / 19
Регистрация: 07.03.2011
Сообщений: 175
25.05.2014, 16:48
Так это грамматика. Опираясь на неё, ведут разбор выражения, если нужно соблюдать приоритет операций: * и / перед + и -, скобки вычисляются первыми и т.д.
0
0 / 0 / 0
Регистрация: 04.12.2013
Сообщений: 52
25.05.2014, 16:58  [ТС]
Чумаков Антон,
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
#include "stdafx.h"
#include <iostream>
using namespace std;
 
 
float number()
{
    int nes = 0;
    for (;;)
    {
        char c = cin.get();
        if (c >= '0' && c <= '9')
            nes = nes * 10 + c - '0';
        else
        {
            cin.putback(c);
            break;
        }
    }
    return nes;
}
 
float expr();
float factor()
{
    float x;
    char c = cin.get();
    if (c == '(')
    {
        x = expr();
        cin.get();
    }
    else
    {
        cin.putback(c);
        x = number();
    }
    c = cin.get();
    switch (c)
    {
    case '*':
        return x * factor();
    case '/':
        return x / factor();
    default:
        cin.putback(c);
            return x;
    }
}
 
float expr()
{
    float x = factor();
    char c = cin.get();
    switch (c)
    {
    case '+':
        return x + expr();
    case '-':
        return x - expr();
    default:
        cin.putback(c);
        return x;
    }
}
 
int main()
{
    setlocale(LC_ALL, "Russian");
    cout << "Введите выражение:";
    float S = expr();
    cout << "Результат:" << S << endl;
 
    system("pause");
}
если я напишу в лоб?

Добавлено через 1 минуту
Чумаков Антон, и в чем в данный момент моя ошибка? Если подводить к моей задаче.
0
88 / 69 / 19
Регистрация: 07.03.2011
Сообщений: 175
25.05.2014, 17:01
Bambaster01,
Цитата Сообщение от Bambaster01 Посмотреть сообщение
если я напишу в лоб?
Очень близкое к вашему и рассматривает Страуструп. Начинает с такого.

Цитата Сообщение от Bambaster01 Посмотреть сообщение
и в чем в данный момент моя ошибка?
Должно быть 4 функции:
Первая получает Выражение, вторая - Терм, третья - Элемент, 4-я - Цифру.
0
0 / 0 / 0
Регистрация: 04.12.2013
Сообщений: 52
25.05.2014, 17:03  [ТС]
Чумаков Антон, я просто не могу понять как это можно вообще реализовать)
0
88 / 69 / 19
Регистрация: 07.03.2011
Сообщений: 175
25.05.2014, 17:06
Сейчас покажу готовый код.

Добавлено через 1 минуту
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<fstream>
#include<sstream>
#include<cmath>
#include<cstdlib>
#include<string>
#include<vector>
#include<algorithm>
#include<stdexcept>
 
class Token {
public:
    char kind;        // what kind of token
    double value;     // for numbers: a value 
    Token(char ch)    // make a Token from a char
        :kind(ch), value(0) { }    
    Token(char ch, double val)     // make a Token from a char and a double
        :kind(ch), value(val) { }
};
 
Token get_token()    // read a token from cin
{
    char ch;
    cin >> ch;    // note that >> skips whitespace (space, newline, tab, etc.)
 
    switch (ch) {
 //not yet   case ';':    // for "print"
 //not yet   case 'q':    // for "quit"
    case '(': case ')': case '+': case '-': case '*': case '/': 
        return Token(ch);        // let each character represent itself
    case '.':
    case '0': case '1': case '2': case '3': case '4':
    case '5': case '6': case '7': case '8': case '9':
        {    
            cin.putback(ch);         // put digit back into the input stream
            double val;
            cin >> val;              // read a floating-point number
            return Token('8',val);   // let '8' represent "a number"
        }
    default:
        error("Bad token");
    }
}
 
double expression();  // read and evaluate a Expression
double term();        // read and evaluate a Term
double primary()     // read and evaluate a Primary
{
    Token t = get_token();
    switch (t.kind) {
    case '(':    // handle '(' expression ')'
        {    
            double d = expression();
            t = get_token();
            if (t.kind != ')') error("')' expected");
            return d;
        }
    case '8':            // we use '8' to represent a number
        return t.value;  // return the number's value
    default:
        error("primary expected");
    }
}
 
int main()
{
    while (cin)
        cout << expression() << '\n';
}
catch (exception& e) {
    cerr << e.what() << endl;
    return 1;
}
catch (...) {
    cerr << "exception \n";
    return 2;
}
 
//------------------------------------------------------------------------------
 
double expression() {
    double left = term();      // read and evaluate a Term
    Token t = get_token();     // get the next token
    while(true) {    
        switch(t.kind) {
        case '+':
            left += term();    // evaluate Term and add
            t = get_token();
            break;
        case '-':
            left -= term();    // evaluate Term and subtract
            t = get_token();
            break;
        default:
            return left;       // finally: no more + or -: return the answer
        }
    }
}
 
//------------------------------------------------------------------------------
 
double term() {
    double left = primary();
    Token t = get_token();     // get the next token
 
    while(true) {
        switch (t.kind) {
        case '*':
            left *= primary();
            t = get_token();
            break;
        case '/':
            {    
                double d = primary();
                if (d == 0) error("divide by zero");
                left /= d; 
                t = get_token();
                break;
            }
        default: 
            return left;
        }
    }
}
0
0 / 0 / 0
Регистрация: 04.12.2013
Сообщений: 52
25.05.2014, 17:14  [ТС]
Чумаков Антон, это же вроде получается готовый код.

Добавлено через 27 секунд
Чумаков Антон, только без цикла и есть отдельный класс.
0
88 / 69 / 19
Регистрация: 07.03.2011
Сообщений: 175
25.05.2014, 17:19
Bambaster01,
Цитата Сообщение от Bambaster01 Посмотреть сообщение
это же вроде получается готовый код.
как бы да. Беда в том, что сразу понять, что там и для чего, довольно сложно.

Добавлено через 3 минуты
Цитата Сообщение от Bambaster01 Посмотреть сообщение
только без цикла
Ну, циклы там есть, только в других местах, да. А с классом это куда проще и удобнее.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
25.05.2014, 17:19
Помогаю со студенческими работами здесь

Интерпретатор выражений с переменной(разбор и анализ строки))
Может у кого есть библиотечка по данному сабжу? В идеале надо чтобы пользователь мог вводить любую функцию y=f(x) и для любого значения...

Написать парсер математических выражений с функцией упрощения этих выражений
Люди, здравствуйте. Есть такая задача: написать упроститель выражений. На вход подается строка вида &quot;a*b+a*c&quot;, являющаяся...

Запись выражений, ввод–вывод информацииЗапись выражений, ввод–вывод информации
Задача 2.1. Пользуясь только операцией умножения, вычислить (A в 7-ой степени) за четыре операции. Задача 2.2. Очистить экран,...

Разбор выражений
В общем в тупике не знаю даже с чего начать. Рассчитываю на вашу помощь. Условие: Вывести значение целочисленного выражения,...

Разбор логических выражений
Добрый день. Подскажите как сделать разбор логического выражения! например, на вхоl программы приходит строка: (a + b) &amp; (c &lt;...


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
Жизнь в неопределённости
kumehtar 23.03.2026
Жизнь — это постоянное существование в неопределённости. Например, даже если у тебя есть список дел, невозможно дойти до точки, где всё окончательно завершено и больше ничего не осталось. В принципе,. . .
Модель здравоСохранения: работники работают быстрее после её введения.
anaschu 23.03.2026
geJalZw1fLo Корпорация до введения программа здравоохранения имела много невыполненных работниками заданий, после введения программы количество заданий выросло. Но на выплатах по больничным это. . .
1С: Контроль уникальности заводского номера
Maks 23.03.2026
Алгоритм контроля уникальности заводского (или серийного) номера на примере документа выдачи шин для спецтехники с табличной частью. Данные берутся из регистра сведений, по которому настроено. . .
Хочу заставить корпорации вкладываться в здоровье сотрудников: делаю мат модель здравосохранения
anaschu 22.03.2026
e7EYtONaj8Y Z4Tv2zpXVVo https:/ / github. com/ shumilovas/ med2. git
1С: Программный отбор элементов справочника по группе
Maks 22.03.2026
Установка программного отбора элементов справочника "Номенклатура" из модуля формы документа. В качестве фильтра для отбора справочника служит группа номенклатуры. Отбор по наименованию группы. . .
Как я обхитрил таблицу Word
Alexander-7 21.03.2026
Когда мигает курсор у внешнего края таблицы, и нам надо перейти на новую строку, а при нажатии Enter создается новый ряд таблицы с ячейками, то мы вместо нервных нажатий Энтеров мы пишем любые буквы. . .
Krabik - рыболовный бот для WoW 3.3.5a
AmbA 21.03.2026
без регистрации и смс. Это не торговля, приложение не содержит рекламы. Выполняет свою непосредственную задачу - автоматизацию рыбалки в WoW - и ничего более. Однако если админы будут против -. . .
1С: Программный отбор элементов справочника по значению перечисления
Maks 21.03.2026
Установка программного отбора элементов справочника "Сотрудники" из модуля формы документа. В качестве фильтра для отбора служит значение перечислений. / / Событие "НачалоВыбора" реквизита на форме. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru