Исполнитель Редактор получает на вход cтроку цифр и преобразует её. Редактор может выполнять две команды, в обеих командах и
обозначают цепочки цифр.
А) .
Эта команда заменяет в строке первое слева вхождение цепочки на цепочку
. Например, выполнение команды
преобразует строку в строку
.
Если в строке нет вхождений цепочки , то выполнение команды заменить
не меняет эту строку.
Б) .
Эта команда проверяет, встречается ли цепочка в строке исполнителя Редактор. Если она встречается, то команда возвращает логическое значение
, в противном случае возвращает значение
. Строка исполнителя при этом не изменяется.
Цикл
выполняется, пока условие истинно.
Дана программа для редактора:
Какая строка получится в результате применения приведённой выше программы к строке, состоящей из идущих подряд цифр
? В ответе запишите полученную строку.
Решение руками
Исполнитель будет заменять по четыре единицы на одну (уменьшать количество единиц на ). Тогда
. Столько единиц у нас останется в конце работы алгоритма.
Решение программой
s = ’1’ * 13
while ’1111’ in s:
s = s.replace(’1111’, ’1’, 1)
print(s)