Слово называется палиндромом, если оно читается одинаково, как слева направо, так и справа налево. Требуется определить, какое минимальное количество букв надо добавить к входному слову справа, чтобы оно стало палиндромом. На вход программе подается строка, состоящая не более чем из 255 символов. Выведите искомое число. паскаль
Ответы
Ответ дал:
0
Var s : String;
Function isPali(ss : String) : Boolean;
Begin
If Length(ss)>0 then isPali:=(ss[1]=ss[Length(ss)]) and isPali(Copy(ss,2,Length(ss)-2))
else isPali:=True;
end;
Function NtoPali(ss : String) : Integer;
Begin
If isPali(ss) then NtoPali:=0 else NtoPali:=1+NtoPali(Copy(ss,2,Length(ss)-1));
end;
Begin
s:='abcdc'; // Readln(s);
Writeln(NtoPali(s));
end.
Function isPali(ss : String) : Boolean;
Begin
If Length(ss)>0 then isPali:=(ss[1]=ss[Length(ss)]) and isPali(Copy(ss,2,Length(ss)-2))
else isPali:=True;
end;
Function NtoPali(ss : String) : Integer;
Begin
If isPali(ss) then NtoPali:=0 else NtoPali:=1+NtoPali(Copy(ss,2,Length(ss)-1));
end;
Begin
s:='abcdc'; // Readln(s);
Writeln(NtoPali(s));
end.
Вас заинтересует
1 год назад
1 год назад
6 лет назад
9 лет назад