Исполнитель Редактор получает на вход строку цифр и преобразует её. Редактор может выполнять две команды, в обеих
А) заменить (v, w).
Эта команда заменяет в строке первое слева вхождение
Если в строке нет вхождений
Б) нашлось (v).
Эта команда проверяет, встречается ли
Цикл
ПОКА условие
последовательность команд
КОНЕЦ ПОКА
выполняется, пока условие истинно.
Какая строка получится в результате применения приведённой ниже программы к строке, состоящей
НАЧАЛО
ПОКА нашлось (111)
заменить (111, 2)
заменить (222, 3)
заменить (333, 1)
КОНЕЦ ПОКА
КОНЕЦ
Данный алгоритм сначала заменит девять первых единиц на три двойки, а затем заменит эти три двойки на одну тройку. После этого алгоритм заменит ещё
Ответ: 3211.
Приведём другое решение на языке Python.
s = '1' * 66
while '111' in s:
s = s.replace('111', '2', 1)
s = s.replace('222', '3', 1)
s = s.replace('333', '1', 1)
print(s)

