Поделитесь своими знаниями, ответьте на вопрос:
Вам даны две строки s и t, определите длину наибольшей строки, которая встречается в обеих. формат входных данных первая строка входных данных содержит строку s, вторая строка содержит строку t. обе строки состоят только из строчных латинских букв. 1 < = длина строк < = 1, 000. формат выходных данных выведите ответ к .
// Внимание! Если программа не работает, обновите версию!
function MaxSubstr(s1,s2:string):string;
begin
var a:=new integer[s1.Length+1,s2.Length+1];
var u:=0; var v:=0;
for var i:=0 to s1.Length-1 do
for var j:=0 to s2.Length-1 do
if s1[i+1]=s2[j+1] then begin
a[i+1,j+1]:=a[i,j]+1;
if a[i+1,j+1]>a[u,v] then begin u:=i+1; v:=j+1 end
end;
Result:=s1.Substring(u-a[u,v],a[u,v])
end;
begin
var s:='trapperkaperkatrter';
var t:='appekaperspamer';
Writeln(MaxSubstr(s,t))
end.