Исполнитель Панцирь получает на вход строку цифр и преобразовывает её. Панцирь может выполнять две команды, в обеих командах и
обозначают цепочки символов.
1. заменить (,
)
2. нашлось ()
Первая команда заменяет в строке первое слева вхождение цепочки на цепочку
. Если цепочки
в строке нет, эта команда не изменяет строку. Вторая команда проверяет, встречается ли цепочка
в строке исполнителя Панцирь. Если она встречается, то команда возвращает логическое значение «истина», в противном случае возвращает значение «ложь».
Дана программа для исполнителя Панцирь:
НАЧАЛО
ПОКА нашлось ИЛИ нашлось
ИЛИ нашлось
ЕСЛИ нашлось
ТО заменить
ИНАЧЕ ЕСЛИ нашлось
ТО заменить
ИНАЧЕ ЕСЛИ нашлось
ТО заменить
КОНЕЦ ЕСЛИ
КОНЕЦ ПОКА
КОНЕЦ
Какая строка получится в результате применения приведённой выше программы к строке
Решение руками
Для удобства будем использвовать следующие обозначения для количества одинаковых цифр, идущих подряд: где A — цифра, которая находится в строке, а B — количество этих цифр.
Изначально была строка Самое приоритетное действие в цикле ПОКА – это замена 5 на 77. На протяжении всей работы программы оно будет выполняться до тех пор, пока пятерок не останется вообще. Для текущей же строки все пятерки заменятся парами семерок, которых будет в 2 раза больше, чем изначальное количество пятерок, т.е. 74.
Второе по приоритету действие — это замена пары семерок на одну семерку. Это действие перестанет выполняться, когда количество семерок не станет 1.
Теперь можно просчитать вручную, т.к. программа близка к завершению:
Таким образом, в конце выполнения программа будет выведено 722.
Решение программой
s = ’5’ * 37 + ’7’ * 56 + ’2’ * 5
while ’5’ in s or ’77’ in s or ’222’ in s:
if ’5’ in s:
s = s.replace(’5’, ’77’, 1)
elif ’77’ in s:
s = s.replace(’77’, ’7’, 1)
elif ’222’ in s:
s = s.replace(’222’, ’5’, 1)
print(s)