IPB
ЛогинПароль:

> Прочтите прежде чем задавать вопрос!

1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code], либо быть опубликованы на нашем PasteBin в режиме вечного хранения.
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!

 
 Ответить  Открыть новую тему 
> Помогите разобрать решение задачи на нахождение периода строки
сообщение
Сообщение #1





Группа: Пользователи
Сообщений: 6
Пол: Мужской
Реальное имя: Олег

Репутация: -  0  +


Задача:
Ввести строку. Найти её период.

Идея решения:
Необходимо найти K (количество символов в строке), определить делители K и сравнить вырезки из строки по R символов (R - делитель K).

Программа на Паскале:

program period_stroki;
var
s:string;
h,i,j,k,n,p,x:integer;
begin
readln(s);
n:=length(s);
for i:=1 to n do
begin
k:=0;
if n mod i = 0 then
begin
h:=n div i;
x:=1;
for j:=1 to i-1 do {нужен ли здесь -1? программа выполняется правильно и без неё.}
begin
if copy(s,1,h)=copy(s,x+h,h)then k:=k+1;
x:=x+h;
end;
if k=i-1 then p:=h;
end;
end;
write(copy(s,1,p));
end.
{Задача из "Олимпиадные задания с решениями" Лариной Э.С.
Не могу понять ее решения. Пробовал решать на примере - получается какой-то бред. Но ведь решение правильное и период находится.}

 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
сообщение
Сообщение #2


Гость






Цитата(ONi++ @ 26.08.2009 21:02) *

Задача:
Ввести строку. Найти её период.

Идея решения:
Необходимо найти K (количество символов в строке), определить делители K и сравнить вырезки из строки по R символов (R - делитель K).

Программа на Паскале:

program period_stroki;
var
s:string;
h,i,j,k,n,p,x:integer;
begin
readln(s);
n:=length(s);
for i:=1 to n do
begin
k:=0;
if n mod i = 0 then
begin
h:=n div i;
x:=1;
for j:=1 to i-1 do {нужен ли здесь -1? программа выполняется правильно и без неё.}
begin
if copy(s,1,h)=copy(s,x+h,h)then k:=k+1;
x:=x+h;
end;
if k=i-1 then p:=h;
end;
end;
write(copy(s,1,p));
end.
{Задача из "Олимпиадные задания с решениями" Лариной Э.С.
Не могу понять ее решения. Пробовал решать на примере - получается какой-то бред. Но ведь решение правильное и период находится.}



тоже никак не могу разобраться
 К началу страницы 
+ Ответить 

 Ответить  Открыть новую тему 
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 





- Текстовая версия 11.05.2024 12:53
500Gb HDD, 6Gb RAM, 2 Cores, 7 EUR в месяц — такие хостинги правда бывают
Связь с администрацией: bu_gen в домене octagram.name