На этой неделе на уроках информатики васе рассказывают про строки.
вчера вася узнал, что такое циклический сдвиг:
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
Для начала давайте определим сколько памяти требуется для хранения одного символа. Для этого вспомним главную формулу информатики
Здесь i — количество бит на 1 символ, а N — количество различных символов. По условию задачи у нас всего 26 символов, значит подставим вместо N число 26 и получим
Теперь нужно понять чему равно i. Если i = 4, то 2 4 = 16. Т. е. 4 бита на 1 символ позволит закодировать 16 символов, а у нас их 26. Маловато будет.
Если i=5, то 2 5 = 32. На наши 26 символов этого хватит. Значит на 1 символ у нас будет приходится 5 бит информации.
Так как в пароле у нас 7 символов, то на 1 пароль потребуется 7*5 =35 бит памяти. В байтах это будет 35/8 = 4,375. Округлим в большую сторону (так как по условию «для
каждого пользователя в системе хранятся дополнительные сведения, для чего выделено целое число байт») и получим, что на хранение пароля пользователя требуется 5 байт памяти.
Так как на 30 пользователей отводится 600 байт памяти, то на одного пользователя требуется 600/30 = 20 байт памяти. Из них 5 байт отводится для пароля. Следовательно для дополнительных сведений остается 20 — 5 = 15 байт.
1. сначала тексты вырезали на камнях и глиняных табличках, позже для этого стали использовать краски.
2. задание в компе надо сделать
3. было разработано множество программ для записи, хранения, обработки и печати на бумаге текстов.
4. основные элементы текстового редактора- рабочее поле, курсор и меню показаны на рисунке.
5. рабочее поле блокнота это область текстового ввода, а область рабочего стола это графическая среда в виде папки.
6. текстовые редакторы-ввод текста с минимальным набором операций.
текстовые процессоры-ввод в текст различных объектов и широкий набор операций.
7. строка меню содержит набор специальных команд и действий для работы с текстом. с их выполняются чтение текста с диска, запись на диск, распечатка и т.д.
8. Программа простейшего текстового редактора Блокнот предназначена для выполнения различных записей по усмотрению программиста, например, типа краткое описание файлов в различных папках, серийные номера, коды и пароли программных продуктов, запускаемых с винчестера или загружаемых с компакт-диска.
9. извините не знаю!(
Объяснение: ответ правильный )