Задания
Версия для печати и копирования в MS Word
Тип 23 № 73878
i

Ис­пол­ни­тель пре­об­ра­зу­ет число на экра­не.

У ис­пол­ни­те­ля есть две ко­ман­ды, ко­то­рые обо­зна­че­ны бук­ва­ми:

A. Вычти 3

B.  Если число чётное, Раз­де­ли на 2, Иначе Вычти 5

Про­грам­ма для ис­пол­ни­те­ля  — это по­сле­до­ва­тель­ность ко­манд.

Сколь­ко су­ще­ству­ет про­грамм, ко­то­рые пре­об­ра­зу­ют ис­ход­ное число 36 в число 4 и при этом тра­ек­то­рия вы­чис­ле­ний не со­дер­жит числа 16?

Тра­ек­то­рия вы­чис­ле­ний про­грам­мы  — это по­сле­до­ва­тель­ность ре­зуль­та­тов вы­пол­не­ния всех ко­манд про­грам­мы. На­при­мер, для про­грам­мы BAB при ис­ход­ном числе 100 тра­ек­то­рия будет со­сто­ять из чисел 50, 47, 42.

Спрятать решение

Ре­ше­ние.

При­ведём ре­ше­ние на языке Python.

def f(x, y):

if x < y or x == 16:

return 0

if x == y:

return 1

if x % 2 == 0:

return f(x - 3, y) + f(x // 2, y)

else:

return f(x - 3, y) + f(x - 5, y)

print(f(36, 4))

 

Ответ: 21.


Аналоги к заданию № 73878: 73849 Все