Форум программистов, компьютерный форум, киберфорум
Python: Решение задач
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/6: Рейтинг темы: голосов - 6, средняя оценка - 5.00
-2 / 6 / 5
Регистрация: 19.01.2022
Сообщений: 201

Сбалансированная подстрока

21.02.2022, 17:20. Показов 1480. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Дана строка s, состоящая из n букв, каждая буква — либо 'a', либо 'b'. Буквы в строке пронумерованы от 1 до n.

s[l;r] — это подстрока подряд идущих букв с позиции l до позиции r строки включительно.

Строка называется сбалансированной, если количество букв 'a' в ней равно количеству букв 'b'. Например, строки «baba» и «aabbab» сбалансированные, а строки «aaab» и «b» — нет.

Найдите любую непустую сбалансированную подстроку s[l;r] строки s. Выведите ее l и r (1≤l≤r≤n). Если таких подстрок нет, то выведите −1 −1.




Входные данные:
В первой строке записано одно целое число t (1≤t≤1000) — количество наборов входных данных.

Затем следуют описания t наборов входных данных.

В первой строке набора входных данных записано одно целое число n (1≤n≤50) — длина строки.

Во второй строке набора входных данных записана строка s, состоящая из n букв, каждая буква — либо 'a', либо 'b'.





Выходные данные:
На каждый набор входных данных выведите два целых числа. Если существует непустая сбалансированная подстрока s[l;r], то выведите l r (1≤l≤r≤n). В противном случае выведите −1 −1.




Пример:
входные данные
4
1
a
6
abbaba
6
abbaba
9
babbabbaa

выходные данные
-1 -1
1 6
3 6
2 5


Примечание:
В первом наборе входных данных нет непустых сбалансированных подстрок.

Во втором и в третьем наборах входных данных есть несколько сбалансированных подстрок, включая всю строку «abbaba» и подстроку «baba».
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
21.02.2022, 17:20
Ответы с готовыми решениями:

Разнообразная подстрока
Задана строка s, состоящая из n строчных букв латинского алфавита. Подстрока строки s — это последовательный отрезок букв из s....

Наибольшая общая подстрока
Добрый день может кто-то знает как решить задачу? Заранее всем спасибо!!! Даны K строк из маленьких латинских букв. Требуется найти их...

Выяснить, есть ли у двух строк общая подстрока длиной L
Условие Даны две строки s и t. Выясните, есть ли у них общая подстрока длиной L. Формат входных данных В первой строке вводится...

5
2431 / 1474 / 633
Регистрация: 01.11.2021
Сообщений: 2,269
21.02.2022, 18:07
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
def func(s):
    ma = 0
    x, y = -1, -1
    for i in range(len(s) - 2):
        for j in range(i + 2, len(s)):
            if s[i:j + 1].count('a') == s[i:j + 1].count('b') and j + 1 - i > ma:
                ma = j + 1 - i
                x, y = i + 1, j + 1
    return x, y
 
 
t = int(input())
arr = []
for i in range(t):
    n = int(input())
    arr.append(input())
 
r = list(map(func, arr))
print(*r, sep='\n')
0
Status 418
Эксперт Python
4584 / 2350 / 601
Регистрация: 26.11.2017
Сообщений: 5,262
Записей в блоге: 3
21.02.2022, 18:28
Alexarh, по времени не пройдет.
0
-2 / 6 / 5
Регистрация: 19.01.2022
Сообщений: 201
21.02.2022, 18:33  [ТС]
надо без скобок выводить их
0
Status 418
Эксперт Python
4584 / 2350 / 601
Регистрация: 26.11.2017
Сообщений: 5,262
Записей в блоге: 3
21.02.2022, 18:37
shinzin, ну так выведи. всем сложность?
0
-2 / 6 / 5
Регистрация: 19.01.2022
Сообщений: 201
21.02.2022, 18:40  [ТС]
не очень понимаю как тут без скобок это вывести
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
21.02.2022, 18:40
Помогаю со студенческими работами здесь

Переписать в новый файл все его строки, в которых содержится заданная подстрока
Дан текстовый файл. Вывести на экран все строки с номерами от k1 до k2. Переписать в новый файл все его строки, в которых содержится...

Вывести все позиции, с которых подстрока встречается в строке
Смысл программы в том, что даны строка и подстрока, программа выводит все позиции, с которых подстрока встречается в строке. есть код,...

Определить сколько раз в строке встречается заданная подстрока
Заданная строка Т. Необходимо определить количество различных подстрок строки Т. Пустой подстроку учитывать не следует. Входные данные ...

Regexp, который выдаёт соответствие только если подстрока встречается лишь единожды
На входе есть строка вида foo, где каждый тэг - набор заранее определённых слов, каждое из которых должно быть использовано не более одного...

Образует ли подстрока, начинающаяся с символа номер m и заканчивающаяся символом номер n, число 666?
совсем понять не могу, как это написать условие: Дана строка. Определить, образует ли подстрока, начинающаяся с символа номер m и ...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru