Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.57/333: Рейтинг темы: голосов - 333, средняя оценка - 4.57
10 / 59 / 21
Регистрация: 12.03.2017
Сообщений: 514

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

07.12.2017, 21:04. Показов 71073. Ответов 23
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Правильной скобочной последовательностью называется строка, состоящая только из символов "скобки" (открывающих "(" и закрывающих ")"), где каждой закрывающей скобке найдётся соответствующая открывающая. Например, () и (()()) - правильные последовательности, а (()(() или )( - нет.

Напишите функцию Bracket_check(), которая проверяет, является ли поступившая на вход строка правильной скобочной последовательностью. Если да, она должна печатать YES, в противном случае - NO. Обратите внимание, что пустая строка также является правильной скобочной последовательностью.
Пример 1
Ввод
()
Вывод
YES

Пример 2
Ввод
(()((
Вывод
NO
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
07.12.2017, 21:04
Ответы с готовыми решениями:

Проверка скобочной последовательности
Делал проверку на скобочную последовательность (состоящую из круглых скобок) на правильность, но она всегда пишет неправильно... ...

Корректность скобочной последовательности
Правильной скобочной последовательностью с 2n скобок называется такая последовательность, которая может встречаться в некотором...

Проверить код на правильность
Подскажите, в чем ошибки? Я не понимаю, что значит точность. Куда ее подставлять? import matplotlib.pyplot as plt import math ...

23
5525 / 2878 / 572
Регистрация: 07.11.2019
Сообщений: 4,773
04.04.2020, 22:10
Студворк — интернет-сервис помощи студентам
Ksmnwt, правильное замечание. В цикле надо проверять что не ушли в минус.
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
a='(()())'
n=0
res='yes'
for i in a:
    if i=='(':
        n+=1
    if i==')':
        n-=1
    if n<0:
        res='no'
        break
if n!=0:
    res='no'
print(res)
Добавлено через 21 минуту
Python
1
2
3
4
5
6
7
from itertools import accumulate
ans=['no', 'yes']
a='(()())'
b={'(':1,')':-1}
c=[b[i] for i in a]
d=[i for i in accumulate(c) if i<0]
print(ans[(len(d)==0)*(sum(c)==0)])
0
Status 418
Эксперт Python
4584 / 2350 / 601
Регистрация: 26.11.2017
Сообщений: 5,262
Записей в блоге: 3
04.04.2020, 22:28
https://www.cyberforum.ru/post14172930.html
0
 Аватар для Stepaotboga
17 / 14 / 3
Регистрация: 25.12.2022
Сообщений: 27
13.01.2023, 23:14
Цитата Сообщение от LiKin Посмотреть сообщение
не может быть больше открывающих
У тебя не совсем правильное решение. В условии говорится что не подходит ")(". Если проходится по твоему алгоритму то при считывании ")" от переменной result отнимается 1 и она теперь равна -1. При считывании "(" прибавляется 1 и теперь переменная равна 0. Вход считали, выходим из цикла, result равен 0, ответ OK

Я предлагаю отнимать 1 при считывании ")" если сама переменная больше 0

Добавлено через 17 минут
Вот сделал
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
def bracket_check(test_string):
    flag = 0
    for i in test_string:
        if i == '(':
            flag += 1
        if i == ')' and flag > 0:
            flag -= 1
    if flag != 0:
        print('NO')
    elif test_string.count('(') != test_string.count(')'):
        print('NO')
    else:
        print('YES')
 
 
bracket_check('(()((')
0
13.01.2023, 23:50

Не по теме:

Ахах, неплохо)

Вложения
Тип файла: webp i.webp (30.7 Кб, 2 просмотров)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
13.01.2023, 23:50
Помогаю со студенческими работами здесь

Проверить правильность написания круглых скобок
Проверить правильность написания круглых скобок.питон

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

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

Проверить правильность расстановки скобок, если их n пар
Проверить правильность расстановки скобок, если их n пар. python Спасибо заранее!!!

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


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

Или воспользуйтесь поиском по форуму:
24
Ответ Создать тему
Новые блоги и статьи
[golang] Угол между стрелками часов
alhaos 12.05.2026
По заданным значениям часа и минуты необходимо определить значение меньшего угла между стрелками аналогового циферблата часов. import "math" func angleClock(hour int, minutes int) float64 { . . .
Debian 13: Установка Lazarus QT5
ВитГо 09.05.2026
Эта инструкция моя компиляция инструкций volvo https:/ / www. cyberforum. ru/ blogs/ 203668/ 10753. html и его же старой инструкции по установке Lazarus с gtk2. . .
Нейросеть на алгоритме "эстафета хвоста" как перспектива.
Hrethgir 06.05.2026
На десерт, когда запущу сервер. Статья тут https:/ / habr. com/ ru/ articles/ 1030914/ . Автор я сам, нейросеть только помогает в вопросах которые мне не известны - не знаю людей которые знали-бы. . .
Асинхронный приём данных из COM-порта
Argus19 01.05.2026
Асинхронный приём данных из COM-порта Купил на aliexpress термопринтер QR701. Он оказался странным. Поключил к Arduino Nano. Был очень удивлён. Наотрез отказывается печатать русские буквы. Чтобы. . .
попытка написать игровой сервер на C++
pyirrlicht 29.04.2026
попытка написать игровой сервер на плюсах с открытым бесконечным миром. возможно получится прикрутить интерпретатор питон для кастомизации игровой логики. что есть на текущий момент:. . .
Контроль уникальности выбранного документа-основания при изменении реквизита
Maks 28.04.2026
Алгоритм из решения ниже разработан на примере нетипового документа "ЗаявкаНаРемонтСпецтехники", разработанного в КА2. Задача: уведомлять пользователя, если указанная заявка (документ-основание). . .
Благородство как наказание
Maks 24.04.2026
У хорошего человека отношения с женщинами всегда складываются трудно. А я человек хороший. Заявляю без тени смущения, потому что гордиться тут нечем. От хорошего человека ждут соответствующего. . .
Валидация и контроль данных табличной части документа перед записью
Maks 22.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в КА2. Задача: контроль и валидация данных табличной части документа перед записью с учетом регламента компании. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru