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

Правильность расстановки скобок

31.05.2017, 04:10. Показов 11793. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всё обыскал но никак не могу найти именно то, что мне нужно, а именно:
Используя классы, создать бинарное дерево. В узлах бинарного дерева имеется элемент (целое число), являющийся ключом. В записях дерева хранятся строки знаков (не более 80 символов). Среди знаков могут быть открывающие и закрывающие скобки (круглые, квадратные, фигурные). В дереве не более 50 узлов. Элементы дерева заполнять из файла. Реализовать функцию вывода дерева на экран. Реализовать функцию, которая проверяет, предшествует ли каждая открывающая скобка соответствующей закрывающей (т.е. правильность расстановки скобок). Вывести на экран значение ключа узла, если скобки расставлены правильно. Если нет, то кроме значения ключа вывести номер позиции открывающей скобки и номер ошибочной позиции.
Со всем в принципе разобрался, только вот с ошибочными позициями никак не разберусь... буду очень признателен за помощь!
Вот мой код проверки правильности расстановки скобок:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
string CheckIntegrity(string src)
{
    string ss="";
        for (int i = 0; i < src.length(); i++)
        {
            if (src[i] == '(' || src[i] == '{' || src[i] == '[' || src[i] == ')' || src[i] == '}' || src[i] == ']')
            ss += src[i];
        }
        for (int i = 0; i < ss.length(); i++)
        {
            if ((ss[i] == '(' && ss[i + 1] == ')') || (ss[i] == '[' && ss[i + 1] == ']') || (ss[i] == '{' && ss[i + 1] == '}'))
            {
                ss.erase(i,2);
                i = -1;
            }
        }
    if (ss.length()==0) return " - корректно"; else return " - не корректно";
}
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
31.05.2017, 04:10
Ответы с готовыми решениями:

Проверить правильность расстановки скобок
Помогите написать программу на c++. Дана строка, содержащая латинские буквы и скобки трех видов: «()», «», «{}». Если скобки расставлены...

В символьной строке проверить правильность расстановки скобок
Есть строка, нужно проверить её на правильное раставление скобок. Как это организовать правильно?

Работа со стеком (проверить правильность расстановки скобок)
Дано математическое выражение, к примеру ((a+b)*b(s)() Необходимо проверить,правильно ли расставлены скобки. Проверять следует следующим...

5
 Аватар для anapshy
531 / 272 / 220
Регистрация: 14.11.2016
Сообщений: 1,052
31.05.2017, 10:23
Вывести позицию незакрытой скобки
Мб чем-то поможет (примечание: переведи на С++).

Добавлено через 5 минут
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
 // (с) by LFC; Special for CYBERFORUM
#include <stdio.h>
int main()
{
    char str[] = "(dfghjk))(j)nmbv)))((vf(f)vbb((rt))])";
    int i, count = 0, j = -1, flag = 0;
    for(i = 0; str[i]; i++){
        if(str[i] == '('){
            if(!count)
                j = i;
            count++;
        }
        if(str[i] == ')')
            count--;
        if(count < 0){
            if(!flag){
                printf("First extra right bracket #%d\n", i+1); // Не закрыта правая скобка
                flag = 1;
            }
            count = 0;
        }
    }
    if(j >= 0 && count)
        printf("First extra left bracket #%d\n", j+1); // Не закрыта левая скобка
    else
        puts("Extra left bracket not found"); // Все скобки закрыты
    return 0;
}
0
с++
1282 / 523 / 225
Регистрация: 15.07.2015
Сообщений: 2,562
31.05.2017, 10:24
Лучший ответ Сообщение было отмечено oxy-fox как решение

Решение

//пробуй
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 <iostream>
#include <string.h>
using namespace std;
 
int main()
{
    setlocale(LC_ALL, "russian");
 
    char A[80];                     // строка
    char end_open_skobka;           // последн¤¤ открывающа¤ скобка
    char stack[80];
    int pos = -1;
 
    cout << "¬ведите строку: " << endl;
    cin.getline(A, 80);
 
    int round, figured, squared;
 
    round = figured = squared = 0;
 
    for (int i=0; i<strlen(A); i++)
    {
        if (A[i] == '(') round++;   
        else
        if (A[i] == ')') round--;     
        else
        if (A[i] == '{') figured++;
        else
        if (A[i] == '}') figured--;
        else
        if (A[i] == '[') squared++;  
        else
        if (A[i] == ']') squared--;     
 
        if ( (A[i] == '(') || (A[i] == '{') || (A[i] == '[') )
        {
            end_open_skobka = A[i];          
            pos++;                     
            stack[pos] = A[i];         
        }
 
        if (round<0 || figured<0 || squared<0)
        {
            cout << "Ћишн¤¤ закрывающа¤ скобка" << endl;
            break;
        }
 
        if ( ((A[i] == ')') && (end_open_skobka != '('))  ||
             ((A[i] == '}') && (end_open_skobka != '{'))  ||
             ((A[i] == ']') && (end_open_skobka != '[')) )
        {
            cout << "«акрывающа¤ скобка другого типа" << endl;
            break;
        }
 
        if ( (A[i] == ')') || (A[i] == '}') || (A[i] == ']') )
        {
            pos--;                           
            if (pos>=0)
                end_open_skobka = stack[pos];
        }
 
 
    }
 
 
 
    if (round || figured || squared)
        cout << "—кобки расставлены неправильно" << endl;
    else
        cout << "—кобки расставлены правильно" << endl;
 
 
    return 0;
}
1
 Аватар для oxy-fox
0 / 0 / 1
Регистрация: 02.12.2015
Сообщений: 17
31.05.2017, 13:05  [ТС]
anapshy, спасибо за ответ, не проверял, к сожалению, возиться не охота еще с двумя типами скобок и переводом на плюсы
Antikl, всё работает, с небольшой доработкой показывает номера ошибочных позиций, спасибо)
0
 Аватар для zarko97
279 / 39 / 13
Регистрация: 11.10.2015
Сообщений: 405
19.07.2017, 10:46
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
#include <iostream>
#include <string>
#include <map>
#include <stack>
 
std::map<char, char> OpenBracketPair = {
    {')', '('},
    {'}', '{'},
    {']', '['}
};
 
inline bool isOpenBracket(char ch) {
    return ch == '(' || ch == '{' || ch == '[';
}
 
inline bool isClosingBracket(char ch) {
    return ch == ')' || ch == '}' || ch == ']';
}
 
bool areParenthesesGood(std::string& str)
{
    std::stack<char> st;
    for (auto ch : str) {
        if (isOpenBracket(ch)) st.push(ch);
        else if (isClosingBracket(ch)) {
            if (!st.empty() && st.top() == OpenBracketPair[ch])
                st.pop();
            else 
                return false;
        }
    }
    return st.empty();
}
 
int main()
{
    std::string s = "{x+(g-[f+h]*c)-(q+w)})";
    (areParenthesesGood(s)) ? std::cout << "yes" : std::cout << "no";
    system("pause");
    return 0;
}
0
0 / 0 / 0
Регистрация: 09.10.2019
Сообщений: 1
21.12.2019, 21:52
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
#include <iostream>
#include <locale>
#include <string>
#include <stack>
#include <map>
 
using namespace std;
 
size_t check_sequence(string str);
 
int main() {
 
    setlocale(LC_ALL, "Russian");
 
    string str = "";
    cout << "Введите скобочную последовательность >>";
    getline(cin, str);
 
    if (auto result = check_sequence(str))
        cout << "Ошибка в скобочной последовательности на элементе № " << result << endl;
    else
        cout << "Правильная последовательность" << endl;
 
    return 0;
}
 
size_t check_sequence(string str) {
 
    pair<char, char> static const brackets[] = {
        {'(',')'},
        {'[',']'},
        {'{','}'}
    };
 
    size_t brackets_size = sizeof(brackets) / sizeof(brackets[0]);
    stack<size_t> brackets_stack;
    size_t i = 0;
 
    for (i = 0; i < str.length(); i++) {
        for (size_t j = 0; j < brackets_size; j++) {
            if (str[i] == brackets[j].first) {
                brackets_stack.push(j);
                break;
            }
            else if (str[i] == brackets[j].second) {
                if (brackets_stack.empty() || brackets_stack.top() != j)
                    return i + 1;
                brackets_stack.pop();
                break;
            }
        }
    }
 
    if (!brackets_stack.empty())
        return i + 1;
 
    return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
21.12.2019, 21:52
Помогаю со студенческими работами здесь

Проверить правильность расстановки в тексте круглых скобок
Задача: Проверить правильность расстановки в тексте круглых скобок. #include &lt;iostream&gt; #include &lt;cstring&gt; using...

Работа со стеком (проверить правильность расстановки скобок)
Дано математическое выражение, к примеру {x+(g-*c)-(q+w)}. Необходимо проверить,правильно ли расставлены скобки. Проверять следует...

Проверить правильность расстановки в тексте круглых скобок (конечный автомат)
Только начала изучать С++.Необходимо проверить правильность расстановки в тексте круглых скобок. Текст вводится с клавиатуры и...

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

Проверить в тексте файла правильность расстановки открывающих и закрывающих скобок
Помогите, пожалуйста написать программу C++ Дан текстовый файл INPUT.TXT. Проверить в тексте файла правильности расстановки открывающих и...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru