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

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

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

> Наибольшая общая часть строк.
Гость
сообщение 23.06.2005 6:36
Сообщение #1


Гость






Помогите пожалуйста выполнить задачу.
Есть две строки надо выделить наибольшую общую часть из них.
Я вообще не понял чего это значит?


внимательнее с названием темы!

Сообщение отредактировано: Oleg_Z - 23.06.2005 14:34
 К началу страницы 
+ Ответить 
 
 Ответить  Открыть новую тему 
Ответов
klem4
сообщение 28.06.2005 16:22
Сообщение #2


Perl. Just code it!
******

Группа: Модераторы
Сообщений: 4 100
Пол: Мужской
Реальное имя: Андрей

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


помоему это решается так :

uses
crt;
var
s1,s2:string;

function GetMaxStr(var ss1,ss2:string):string;
var
MaxS,Chek:string;
i,right,left:integer;

begin

MaxS:='';

// ss1 - меньшая

i:=1;

repeat

left:=i;

right:=length(ss1);

repeat


Chek:=copy(ss1,left,right-left+1);


if (pos(Chek,ss2)>0)and(Length(Chek)>Length(MaxS)) then
MaxS:=Chek;

dec(right);


until(right-left<length(MaxS));

inc(i);

until (i>length(ss1));


GetMaxStr:=MaxS;

End;




Begin

clrscr;

write('s1 = '); readln(s1);
write('s2 = '); readln(s2);

writeln;

write('Результат : ');

if length(s1)<length(s2) then
writeln(GetMaxStr(s1,s2))
else writeln(GetMaxStr(s2,s1));

readln;

End.



зы в некоторых случаях будут лишние проверки, если надо, можно убрать.

Сообщение отредактировано: klem4 - 28.06.2005 16:25


--------------------
perl -e 'print for (map{chr(hex)}("4861707079204E6577205965617221"=~/(.{2})/g)), "\n";'
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 

Сообщений в этой теме


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

 



- Текстовая версия 26.07.2025 11:25
Хостинг предоставлен компанией "Веб Сервис Центр" при поддержке компании "ДокЛаб"