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

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

У ис­пол­ни­те­ля есть две ко­ман­ды, ко­то­рым при­сво­е­ны но­ме­ра.

1.  При­ба­вить 1.

2.  Умно­жить на 2.

Пер­вая ко­ман­да уве­ли­чи­ва­ет число на экра­не на 1, вто­рая умно­жа­ет его на 2.

Про­грам­ма для ис­пол­ни­те­ля  — это по­сле­до­ва­тель­ность ко­манд. На­при­мер, если в на­чаль­ный мо­мент на экра­не на­хо­дит­ся число 1, то про­грам­ма 212 по­сле­до­ва­тель­но пре­об­ра­зу­ет его в 2, 3, 6.

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

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

Ре­ше­ние.

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

def fn(s, h):

if len(h) >= 3 and len(set(h[-3:])) == 1:

return 0

if s >= 14:

return 1 if s == 14 else 0

return fn(s+1, h+'1') + fn(s*2, h+'2')

 

print(fn(1, '' ))

 

Ответ: 6.

 

При­ве­дем ре­ше­ние Ксе­нии Ель­цо­вой на языке Python.

def fn(s, h,p):

if s > h:

return 0

if s == 14 and not '111' in p and not '222' in p:

return 1

return fn(s + 1,h, p +'1') + fn(s*2, h,p +'2')

print(fn(1, 14,''))


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