Примечание:
Если к числу в двоичной системе счисления приписывать в конец цифры, то число увеличивается и никак не может уменьшится. Поэтому, n<f(n). Следовательно, перебор различных чисел, принадлежащих отрезку [90;160], можно смело ставить до 160 (можно и меньше, но лень расписывать вычисления).
ToBinary - функция перевода числа из десятичной СС в двоичную. Можно писать любой алгоритм, необязательно в точности использовать мой.
FromBinary - функция перевода числа из двоичной СС в десятичную. Можно писать любой алгоритм, необязательно в точности использовать мой.
func - функция, которая выполняет преобразования числа согласно условию (пункты 1, 2, 3, 4).
Код кажется большим только из-за процедур и begin/endов. Без них - всего то 7 строчек :). В скринах можно проверить, действительно ли 19 (40-22+1).
Пример работы:
PascalABC.Net
const n = 'нет';
var
s : string;
l,i : integer;
begin
readln (s);
l := Length(s);
i := 1;
While i <= l-1
do
begin
if s[i] = 'д' then
if s[i+1] = 'а'
then
begin
l := l+1;
delete (s,i,2);
Insert (n,s,i);
end;
i := i +1;
end;
writeln (s);
end.