12.01 Исполнитель «Редактор» – известная строка
Ошибка.
Попробуйте повторить позже
Исполнитель Панцирь получает на вход строку цифр и преобразовывает её. Панцирь может выполнять две команды, в обеих командах v и w обозначают цепочки символов.
1. заменить (v, w)
2. нашлось (v)
Первая команда заменяет в строке первое слева вхождение цепочки v на цепочку w. Если цепочки v в строке нет, эта команда не изменяет строку. Вторая команда проверяет, встречается ли цепочка v в строке исполнителя Панцирь. Если она встречается, то команда возвращает логическое значение «истина», в противном случае возвращает значение «ложь».
Дана программа для исполнителя Панцирь:
НАЧАЛО
ПОКА нашлось ИЛИ нашлось
ЕСЛИ нашлось
ТО заменить
ИНАЧЕ ЕСЛИ нашлось
ТО заменить
КОНЕЦ ЕСЛИ
ЕСЛИ нашлось
ТО заменить
ИНАЧЕ ЕСЛИ нашлось
ТО заменить
КОНЕЦ ЕСЛИ
КОНЕЦ ПОКА
КОНЕЦ
Сколько цифр 7 получится в строке, полученной в результате применения приведённой выше
программы к строке:
Решение руками
Для удобства будем использвовать следующие обозначения для количества одинаковых цифр,
идущих подряд: где A - цифра, которая находится в строке, а B - количество этих
цифр.
Изначально была строка До исчезновения всех пятерок программа будет за 1
итерацию заменять первую встреченную пару пятерок на одну семерку и уменьшать количество
четверок на одну. За 25 итераций получится следующая строка:
Далее действия, которые происходили с пятерками, произойдут и с двойками. В результате за следующие 24 итераций получится следующая строка:
Но после начала следующей итерации, последняя четверка не удалится, т.к. останется последняя, т.е. условие вхождения в цикл выполнено не будет. Тогда итерация закончится удалением одной из семерок из начала строки.
Таким образом, количество оставшихся семерок равно 99.
Решение программой
s = ’5’ * 50 + ’4’ * 50 + ’2’ * 50 + ’7’ * 50 while ’54’ in s or ’27’ in s: if ’55’ in s: s = s.replace(’55’, ’7’, 1) elif ’22’ in s: s = s.replace(’22’, ’7’, 1) if ’44’ in s: s = s.replace(’44’, ’4’, 1) elif ’77’ in s: s = s.replace(’77’, ’7’, 1) result = s.count(’7’) print(result)
Специальные программы

Программа
лояльности v2.0
Приглашай друзей в Школково и получай вознаграждение до 10%!

Крути рулетку
и выигрывай призы!
Крути рулетку и покупай курсы со скидкой, которая привязывается к вашему аккаунту.

Бесплатное онлайн-обучение
Для школьников из приграничных территорий России, проживающих в ДНР, ЛНР, Херсонской, Запорожской, Белгородской, Курской, Брянской областях и Крыму.

Налоговые вычеты
Узнай, как получить налоговый вычет при оплате обучения в «Школково».

Специальное предложение
для учителей
Бесплатный доступ к любому курсу подготовки к ЕГЭ, ОГЭ и олимпиадам от «Школково». Мы с вами делаем общее и важное дело, а потому для нас очень значимо быть чем-то полезными для учителей по всей России!

Вернём деньги за курс
за твою сотку на ЕГЭ
Сдать экзамен на сотку и получить обратно деньги за подготовку теперь вполне реально!