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

Парсинг математических выражений - Итератор: выход за пределы массива

08.09.2014, 12:02. Показов 803. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет, задача написать класс для парсинга мат. выражений (+,-,/,*);
По идее выражение задается конструктору, функция eval возвращает результат, print пишет выражение;
Если использую счетчик позиции при парсинге все нормально, если использую итератор на начало то в парсере проверка if(Iter!=token.end()) не работает.

Кликните здесь для просмотра всего текста
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
#include <string>
#include <iostream>
using std::string; using std::cout; using std::endl; using std::cin; using std::cerr;
#ifndef EXPR_CPP_AZZAZA
#define EXPR_CPP_AZZAZA
class Expr{
    enum Token_value
    {
        NUMBER, PLUS = '+', MINUS = '-', MUL = '*', DIV = '/', LP = '(', RP = ')',END
    };
    double number_value;
    string token;
 
    Token_value curr_tok ;
    string::const_iterator Iter;
 
    void get_token();
    double expr(bool);
    double term(bool);
    double prim(bool);
public:
    Expr(string a) :token(a){ Iter = a.begin(); }
    double eval();
    void print();
};
#endif EXPR_CPP_AZZAZA


Кликните здесь для просмотра всего текста
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
#include "Expr.h"
#include <math.h>
 
void Expr::get_token()
{
    char ch = 0;
    if (Iter!=token.begin())
        ch = *Iter;
    switch (ch)
    {
    case 0:
        curr_tok = END;
    case '*':
    case '/':
    case '+':
    case '-':
    case '(':
    case ')':
    {
                Iter++;
                curr_tok = Token_value(ch);
                break;
    }
    case '0': case '1':case '2': case '3': case '4':case '5': case '6':case '7': case '8':case '9': case '.':
    {
                  Iter++;
                  string buff;
                  buff += ch;
                  while (isdigit(*Iter) || *Iter == '.'){
                      buff +=*Iter;
                      Iter++;
                  }
                  number_value = atof(buff.c_str());
                  curr_tok = NUMBER;
                  break;
    }
    default:
        std::cerr << "Bad token\n";
    }
}
void Expr::print()
{
    cout << token << endl;
}
double Expr::prim(bool get)
{
        if (get) get_token();
        switch (curr_tok)
        {
        case NUMBER:
        {
                       double v = number_value;
                       get_token();
                       return v;
        }
        case MINUS:
            return -prim(true);
        case LP:
        {
                   double e = expr(true);
                   if (curr_tok != RP)  cerr<<("')'expected");
                   get_token();
                   return e;
        }
        default:
        {
                   cout << "tracert " << char(curr_tok) << "\n";
                   return 0;
        }
        }
    }
double Expr::expr(bool get)
{
    double left = term(get);
    for (;;)
        switch (curr_tok)
    {
        case PLUS:
            left += term(true);
            break;
        case MINUS:
            left -= term(true);
            break;
        default:
            return left;
    }
}
double Expr::term(bool get)
{
    double left = prim(get);
    for (;;)
        switch (curr_tok)
    {
        case MUL:
            left *= prim(true);
            break;
        case DIV:
            if (double d = prim(true))
            {
                left /= d;
                break;
            }
            cerr<<"divide by 0";
        default:
            return left;
    }
}
 
double Expr::eval()
{
    get_token();
 
    return expr(false);
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
08.09.2014, 12:02
Ответы с готовыми решениями:

Выход за пределы массива
Заполняю динамический массив случайными числами и вывожу его на экран. Дебажная куча жалуется на использование чужой памяти. Не могу найти...

Выход за пределы массива
#include &lt;assert.h&gt; #include &lt;assert.h&gt; #include &lt;string.h&gt; #include &lt;stdint.h&gt; #include &lt;limits.h&gt; int get_bit(const void...

Выход за пределы массива
Столкнулся со следующей проблемой. Ввожу по формату: Мой код при выполнении выдаёт ошибку. Выход за пределы массива (Access...

2
54 / 54 / 37
Регистрация: 05.09.2013
Сообщений: 1,864
08.09.2014, 12:53
Но у вас написано
C++
1
Iter!=token.begin()
, а не
C++
1
Iter!=token.end()
.
0
50 / 31 / 4
Регистрация: 25.04.2013
Сообщений: 366
08.09.2014, 19:39  [ТС]
это опечатка

Добавлено через 6 часов 9 минут
АП )
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
08.09.2014, 19:39
Помогаю со студенческими работами здесь

Выход за пределы массива
Где-то здесь происходит выход за пределы массива puti, но я не могу его найти уже второй день. Объясните, пожалуйста, в чем моя проблема и...

Выход за пределы массива
По мойму нарушение границ массива в c++ не допускается. Это будет выход за пределы массива и попытка записать элемент в какуюто другую...

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

Выход за пределы динамического массива
#include &lt;iostream&gt; using namespace std; int main() { int** mas = new int*; for(int i=0; i &lt; 20; i++) mas = new...

Проверка на выход на пределы массива
Напишите пожалуста пример кода как этого можна добиться в отдельной функции


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
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
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru