Два игрока, Петя и Ваня, играют в следующую игру. Перед игроками лежит куча камней. Игроки ходят по очереди, первый ход делает Петя. В игре разрешено делать следующие ходы:
— добавить в кучу один камень;
— если количество камней в куче чётно, добавить половину имеющегося количества;
— если количество камней в куче кратно трём, добавить треть имеющегося количества;
— если количество камней в куче не кратно ни двум, ни трём, удвоить кучу.
Например, если в куче
Игра завершается, когда количество камней в куче
Победителем считается игрок, сделавший последний ход, то есть первым получивший кучу, в которой
В начале игры в куче было S камней, 1 ≤ S ≤ 95.
Укажите минимальное
Такое значение S — 48. Своим первым ходом Петя может получить
Приведём решение на языке Python.
def f(x, h):
if x >= 96:
return h % 2 == 0
if h == 0:
return 0
c = [f(x + 1, h - 1)]
if x % 2 == 0:
c += [f(x *3 // 2, h - 1)]
if x % 3 == 0:
c += [f(x *4 // 3, h - 1)]
if x % 2 != 0 and x % 3 != 0:
c += [f(x * 2, h - 1)]
return any (c) if h % 2 != 0 else all(c)
for x in range(1, 96):
if f(x, 2) == 1:
print("Задача 19: ", x)
break
Решим задание с помощью электронных таблиц.
В ячейку B1 введем максимальное значение камней в куче 95.
Для Пети пропишем следующие ходы:
В ячейку D3 — ход =C3+1;
В ячейку D7 — ход =ЕСЛИ(ОСТАТ(C3;2)=0;C3+C3*0,5;-1000);
В ячейку D11 — ход =ЕСЛИ(ОСТАТ(C3;3)=0;C3+C3*1/3;-1000);
В ячейку D15 — ход =ЕСЛИ(И(ОСТАТ(C3;2)<>0;ОСТАТ(C3;3)<>0);C3*2;-1000).
Для Вани пропишем ходы аналогично, соответственно ходам Пети.
Меняя значение
Получим следующую таблицу и подходящее
Файл с решением: Решение.xlsx
Ответ: 48.

