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

Проверить правильность скобочной последовательности используя стек

12.05.2021, 11:06. Показов 2239. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
3. Будем рассматривать последовательности круглых и квадратных скобок, которые открываются и и закрываются () []. Среди всех таких последовательностей выделим правильные - те, которые могут быть получены по следующим правилам:
- пустая последовательность правильная.
- если А и В верны, то и АВ правильная.
- если А правильная, то [A] и (A) правильные.
Например, последовательности () [[]], [() [] ()] [] правильные, а последовательности],) (, (], ([)] - неправильные.
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
12.05.2021, 11:06
Ответы с готовыми решениями:

В файле находится текст программы на Паскале. Используя стек, проверить правильность вложений операторных скобок (begin - end) в этой программе
В файле находится текст программы на Паскале. Используя стек, проверить правильность вложений операторных скобок (begin - end) в этой...

Проверить правильность расстановки и вложенности скобок в тексте (абстрактный стек)
реализовать с помощью связного списка...

Проверить правильность скобочной последовательности
Правильной скобочной последовательностью называется строка, состоящая только из символов "скобки" (открывающих "(" и...

2
Эксперт CЭксперт С++
 Аватар для liv
5120 / 4574 / 855
Регистрация: 07.10.2015
Сообщений: 9,462
12.05.2021, 12:15
Лучший ответ Сообщение было отмечено Vitalii15 как решение

Решение

Vitalii15, можешь взять за основу:
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
#include <iostream>
#include <stack>
using namespace std;
 
int main()
{
    string str = "[() [] ()] []";
    stack<char> st;
    bool fOk = true;
    for (size_t i = 0; fOk && i < str.size(); ++i)
    {
        switch (str[i])
        {
            case '(':
            case '{':
            case '[':
                st.push(str[i]);
                break;
 
            case ')':
                if (!st.empty())
                {
                    if (st.top() != '(')
                        fOk = false;
                    st.pop();
                }
                else
                    fOk = false;
                break;
 
            case '}':
                if (!st.empty())
                {
                    if (st.top() != '{')
                        fOk = false;
                    else
                        st.pop();
                }
                else
                    fOk = false;
                break;
            case ']':
                if (!st.empty())
                {
                    if (st.top() != '[')
                        fOk = false;
                    st.pop();
                }
                else
                    fOk = false;
        }
    }
    if (fOk && st.empty())
        cout << "Yes" << endl;
    else
        cout << "No" << endl;
}
0
1 / 1 / 0
Регистрация: 18.12.2020
Сообщений: 17
12.05.2021, 20:25  [ТС]
Спасибо
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
12.05.2021, 20:25
Помогаю со студенческими работами здесь

Используя стек, проверить правильность вложений циклов
Нужна помощь в написании задачки. Буду очень благодарен за любую оказанную помощь ... В файле находится текст программы на Паскале....

Используя стек, проверить правильность вложений циклов
Подскажите что-нибудь по написанию програмки.Ваш вечный должник, olegas=)) В файле находится текст программы на Паскале. Используя...

Используя стек проверить правильность вложений операторных скобок
в файле находится текст программы на c# . используя стек проверить правильность вложений операторных скобок ({}) в этой программе

Используя стек, проверить правильность вложений в этой программе
Нужна помощь с выполнением данного задания (В файле находится текст программы на Паскале. Используя стек, проверить правильность...

Используя стек, проверить правильность вложений операторных скобок (begin/end)
В файле находится текст программы на pascal. используя стек проверить правильность вложений операторных скобок (begin/end) в этой...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru