-2 / 6 / 5
Регистрация: 19.01.2022
Сообщений: 201

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

21.02.2022, 17:20. Показов 1482. Ответов 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 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11680&d=1772460536 Одним из. . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
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 секунды (а то и больше),. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru