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

Работа со строками на С++ проверка на согласованность скобок.

14.01.2010, 00:21. Показов 3056. Ответов 11
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
В арифметическом выражении проверить согласованность скобок, правильность их расположения и выдать соответствующее сообщение.
Если можно нужно чтобы прога работала в Borland C++ v3.1
Буду благодарен за любую помощь.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
14.01.2010, 00:21
Ответы с готовыми решениями:

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

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

Операции со строками. Проверить соответствие открывшихся скобок с закрывшимися
в строке записано сложное условие например(а>b) and (a<d) or (c=a) программа прверяет соответствие открывшихся скобок с закрывшимися,т.е....

11
 Аватар для GAME
23 / 23 / 5
Регистрация: 31.10.2009
Сообщений: 199
14.01.2010, 00:55
Когда только начинал изучать С, писал =))) ФУн-я примитивная малька. Проверяет введённую строку на правильность скобок , если всё норм возвращает 0 , если плохо -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
int test_buf(char *string)
{
    int i,sio,sic;//sic/sio-колво скобок, c - close , o -open    
    i=0;
    sio=0;
    sic=0;
    while(*string!='#')
    {
        ch=*string;
        i++;
        if (sic>sio) return -1;
        if (ch=='(') 
        {
            sio++;
            i=1;
        }
        if (ch==')') 
        {
            sic++;
            if(i==2) return -1;
        }
        *string++;
    }
    if (sio!=sic) return -1;
    return 0;
}
0
Автор FAQ
 Аватар для insideone
3687 / 964 / 114
Регистрация: 10.01.2010
Сообщений: 2,550
14.01.2010, 01:01
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
for (int i = 0; i < кол_во_символов_в_строке; i++)
switch (текущий_символ)
{
case ' ': break; // пробелы пропускаем
case '(':
   {
       счетчик_открытых++;
       if ( ожидаем_откр_скобку == false )
       {
           /* ВЫВОД: ошибка. На i-ом символе открыта неверная скобка */
           return;
       }
       ожидаем_значение = true;
       ожидаем_закр_скобку = false;
       ожидаем_откр_скобку = false;
       ожидаем_операцию = false;
   }
   break;
case '*': case '/': /* и другие арифм. операции */
   {
       if ( ожидаем_операцию == false )
       {
            /* ВЫВОД: ошибка. На i-ом символе использована некорректная операция */
            return;
       }
       ожидаем_значение = true;
       ожидаем_закр_скобку = false;
       ожидаем_откр_скобку = true;
       ожидаем_операцию = false;
   }
   break;
case ')':
   {
       счетчик_закрытых++;
       if ( ожидаем_закр_скобку == false )
       {
            /* ВЫВОД: ошибка. На i-ом символе использована некорректная закрывающая скобка */
            return;
       }
       ожидаем_значение = false;
       ожидаем_закр_скобку = false;
       ожидаем_откр_скобку = false;
       ожидаем_операцию = true;
   }
   break;
   default: // все остальное считаем цифрами или переменными
   {
       if ( ожидаем_значение == false )
       {
            /* ВЫВОД: ошибка. На i-ом символе два значения подряд без разделяющего знака */
            return;
       }
       ожидаем_значение = false; // после цифры сразу цифра без операции?
       ожидаем_закр_скобку = true;
       ожидаем_откр_скобку = false; // а какую операцию мы со скобкой будем делать?
       ожидаем_операцию = true;
   }
}
 
if (  счетчик_открытых != счетчик_закрытых )
{
   /* ВЫВОД: ошибка. Не все скобки были закрыты */
   return;
}
/* ВЫВОД: Ошибок нет. Выражение верно. */
Надеюсь я верно понял задание. В любом случае этот алгоритм придется доделать, так что обратите внимание на то что допустим 'aa' это две переменные идущие подряд и будет ошибка. Этого можно избежать - попробуйте сами это будет несложно.
Если же вводить выражение типизированного вида вроде: (a + (b*3) - 2)^(2-1) должно все отработать.
1
Эксперт С++
 Аватар для CyBOSSeR
2348 / 1721 / 149
Регистрация: 06.03.2009
Сообщений: 3,675
14.01.2010, 02:43
Ниже представлены функции возвращающие false, если количество открывающихся и закрывающихся скобок не совпадает.
Вариант 1:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
bool IsCorrect(const char* expr)
{
  int open_bracket_count = 0;
  int expr_len           = strlen(expr);
 
  for(int i = 0; i < expr_len; ++i)
    switch(expr[i]){
      case '(': 
        ++open_bracket_count;
        break;
     
      case ')':
        --open_bracket_count;
        break;
    }
     
  return open_bracket_count == 0;
}
Вариант 2:
C++
1
2
3
4
5
6
7
8
#include <algorithm>
 
bool IsCorrect(const char* expr)
{
  int expr_len = strlen(expr);
     
  return std::count(expr, expr + expr_len, '(') == std::count(expr, expr + expr_len, ')');
}
1
 Аватар для GAME
23 / 23 / 5
Регистрация: 31.10.2009
Сообщений: 199
14.01.2010, 14:09
А блин, вспомнил )
C++
1
char ch;
После 4й строчки добавте)
0
2022 / 1621 / 489
Регистрация: 31.05.2009
Сообщений: 3,005
14.01.2010, 16:22
Что-то вроде этого...
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
bool IsCorrect(const std::string& s)
{
        size_t len = s.length();
        std::stack<char> stack;
 
        for(size_t i = 0; i < len; ++i)
        {
                if (s[i] == '(') stack.push(s[i]);
                else if(s[i] == ')')
                {
                        if ( !stack.empty()) stack.pop();
                        else return false;
                }
        }
 
        return stack.empty();
}
Добавлено через 21 минуту
для Borland 3.1 надо будет убрать все std::
1
Эксперт JavaЭксперт С++
 Аватар для M128K145
8384 / 3617 / 419
Регистрация: 03.07.2009
Сообщений: 10,709
14.01.2010, 22:28
rangerx, в борланде 3.1 еще не было плюсовых контейнеров
0
4866 / 3288 / 468
Регистрация: 10.12.2008
Сообщений: 10,570
14.01.2010, 23:57
Цитата Сообщение от Farsait
В арифметическом выражении проверить согласованность скобок, правильность их расположения
это типа ())(()
0
2022 / 1621 / 489
Регистрация: 31.05.2009
Сообщений: 3,005
15.01.2010, 17:03
Цитата Сообщение от M128K145 Посмотреть сообщение
rangerx, в борланде 3.1 еще не было плюсовых контейнеров
Хм... может быть... Но какие-то свои классы там я думаю есть.
Цитата Сообщение от accept Посмотреть сообщение
это типа ())(()
А моя функция разве этого не учитывает?
0
28 / 28 / 6
Регистрация: 25.12.2008
Сообщений: 186
15.01.2010, 17:07
Писал такое на экзамене в конце 1го курса, только скобок было 3 вида...
0
425 / 229 / 87
Регистрация: 25.03.2009
Сообщений: 744
15.01.2010, 17:22
rangerx, в Borland C++ никакой поддержки STL нету даже частичной (насколько я помню)
0
4866 / 3288 / 468
Регистрация: 10.12.2008
Сообщений: 10,570
15.01.2010, 22:40
Цитата Сообщение от rangerx
А моя функция разве этого не учитывает?
да это насчёт счётчиков
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
15.01.2010, 22:40
Помогаю со студенческими работами здесь

Работа со строками, заполнить компоненты строками из файла
Привет! Нужна помощь в заполнении формы В общем, есть форма отправки письма. У нее есть 2 функции, сохранить письмо и открыть письмо (на...

Работа со строками(операции над строками)
Пусть дана последовательность, содержащая от 2 до 50 слов, в каждом из которых от 1 до 8 строчных латинских букв; между соседними словами...

Работа со строками. Функции работы со строками
Дана строка символов. В заданном тексте определить позицию первой точки ‘ . ‘.

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

Проверка расстановки скобок
Проверить правильность расстановки скобок, используя класс стек. Программа работает не во всех случаях. Например, если вводить { ( } ...


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

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Новые блоги и статьи
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 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru