На этой неделе на уроках информатики васе рассказывают про строки.
вчера вася узнал, что такое циклический сдвиг:
k-й циклический сдвиг строки – это строка, полученная перестановкой первых k символов строки в её конец. в частности, 0-й циклический сдвиг строки – это сама строка.
и он написал программу, которая умеет перемещать первый символ строки в её конец k раз, получая таким образом k-й циклический сдвиг строки.
сегодня васе нужно реализовать разворот строки. но у васи тренировка. ему некогда писать новые сложные программы. поэтому он задался вопросом:
можно ли циклическими сдвигами развернуть строку?
своим друзьям вася узнал, на какой строке (да, всего одной) будет тестировать его программу учитель, у которого нет времени рецензировать код каждого ученика. поэтому вопрос :
можно ли циклическими сдвигами развернуть строку s?
ему ответить на этот вопрос.
формат входных данных
первая строка содержит одно целое число n (1≤n≤3⋅105) – длина строки s.
во второй строке – сама строка s, на которой будет тестировать программу васи учитель. состоит строка s только из строчных латинских букв.
формат выходных данных
если строку нельзя развернуть циклическими сдвигами, то выведите число −1. в противном случае выведите такое целое число k (0≤k
пояснение к примеру
0-й циклический сдвиг строки s равен abac.
1-й циклический сдвиг строки s равен baca.
2-й циклический сдвиг строки s равен acab.
3-й циклический сдвиг строки s равен caba.
развёрнутая строка s равна caba.
единственное подходящее k равно трём.
sample input:
4
abac
sample output:
3
напишите программу. тестируется через stdin → stdout
time limit: 3 секунды
memory limit: 256 mb
123
161
Ответы на вопрос:
Реши свою проблему, спроси otvet5GPT
-
Быстро
Мгновенный ответ на твой вопрос -
Точно
Бот обладает знаниями во всех сферах -
Бесплатно
Задай вопрос и получи ответ бесплатно
Популярно: Информатика
-
vlad19941100318.10.2020 15:41
-
IlyaPikarychev18.05.2021 23:22
-
kseniyvolcova06.09.2020 08:49
-
200012017.11.2020 18:51
-
egor53530.04.2023 22:38
-
nauryzbekova29.11.2022 10:14
-
Panovamasha3305.05.2023 19:06
-
eva10072008mailru23.03.2023 12:31
-
арина119817.07.2022 23:13
-
nastyaplokhovanastya28.08.2020 03:12
Есть вопросы?
-
Как otvet5GPT работает?
otvet5GPT использует большую языковую модель вместе с базой данных GPT для обеспечения высококачественных образовательных результатов. otvet5GPT действует как доступный академический ресурс вне класса. -
Сколько это стоит?
Проект находиться на стадии тестирования и все услуги бесплатны. -
Могу ли я использовать otvet5GPT в школе?
Конечно! Нейросеть может помочь вам делать конспекты лекций, придумывать идеи в классе и многое другое! -
В чем отличия от ChatGPT?
otvet5GPT черпает академические источники из собственной базы данных и предназначен специально для студентов. otvet5GPT также адаптируется к вашему стилю письма, предоставляя ряд образовательных инструментов, предназначенных для улучшения обучения.