Новая Школа - онлайн-школа подготовки к ЕГЭ
При поддержке
Тренировки Пробники Статистика Карточки Учебник Об экзамене Учительская
  • Тренажёр заданий ЕГЭ
  • Тренажёр ЕГЭ по Информатике
  • Список заданий №20
  • Задание №20
  • Задание №89437 ЕГЭ Информатике

    Условие задания #89437

    №20 по КИМ

    Два игрока, Петя и Ваня, играют в следующую игру. Перед игроками лежат две кучи камней. Игроки ходят по очереди, первый ход делает Петя. За один ход игрок может добавить в одну из куч (по своему выбору) один камень или увеличить количество камней в куче в два раза. Для того чтобы делать ходы, у каждого игрока есть неограниченное количество камней.

    Игра завершается в тот момент, когда суммарное количество камней в кучах становится не менее 231. Победителем считается игрок, сделавший последний ход, то есть первым получивший такую позицию, при которой в кучах будет 231 или больше камней.

    В начальный момент в первой куче было 17 камней, во второй куче  — S камней; 1 ≤ S ≤ 213.

    Будем говорить, что игрок имеет выигрышную стратегию, если он может выиграть при любых ходах противника.

    Найдите два наименьших значения S, при которых у Пети есть выигрышная стратегия, причём одновременно выполняются два условия:

    —  Петя не может выиграть за один ход;

    —  Петя может выиграть своим вторым ходом независимо от того, как будет ходить Ваня.

    Найденные значения запишите в ответе в порядке возрастания без разделительных знаков.

    Ответ

    Ответ:

    98106

    Решение

    def f(x, y, h):
        if h == 4 and x + y >= 231:
            return 1
        elif h == 4 and x + y < 231:
            return 0
        elif x + y >= 231 and h < 4:
            return 0
        else:
            if h % 2 != 0:
                return f(x + 1, y, h + 1) or f(x, y + 1, h + 1) or f(x * 2, y, h + 1) or f(x, y * 2, h + 1)  # стратегия победителя
            else:
                return f(x + 1, y, h + 1) and f(x, y + 1, h + 1) and f(x * 2, y, h + 1) and f(x, y * 2, h + 1)  # стратегия проигравшего(любой ход)
     
    for x in range(1, 214):
        if f(x, 17, 1) == 1:
            print(x)

    Видеоразбор:

    Понятно ли решение?

    Похожие задания

    15
    Задание №89435Задание №89437Задание №37858Задание №89579Задание №31539Задание №31535Задание №31536Задание №31538Задание №31930Задание №31929Задание №31933Задание №32077Задание №31921Задание №37872Задание №37875
    Бесплатно

    Решай задачи ЕГЭ в приложении

    Скачивай наш Тренажер ЕГЭ на iPhone или Android и тренируйся в любое время и в любом месте!

    Саша — ассистент в телеграмме