Слово называется палиндромом, если оно читается одинаково, как слева направо, так и...

0 голосов
171 просмотров

Слово называется палиндромом, если оно читается одинаково, как слева направо, так и справа налево. Требуется определить, какое минимальное количество букв надо добавить к входному слову справа, чтобы оно стало палиндромом. На вход программе подается строка, состоящая не более чем из 255 символов. Выведите искомое число. паскаль


Информатика (31 баллов) | 171 просмотров
0

Непохоже это на школьную задачу.

0

олипиадные задачи это

0

А смысл участвовать в олимпиадах, если у Вас для них не хватает знаний и умений?

0

я написала что это олимпиадные задачи, это не означает что я участвую в олимпиадах, просто задачи олимпиадные!!!!

0

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

0

у меня там еще 6 задач, не могли бы посмотреть? буду благодарна)

Дан 1 ответ
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.

(5.1k баллов)