На этом форуме отвечают на конкретные вопросы. Фраза «я не понимаю, как решать» — это не вопрос. На вопрос «как решить задачу №X» вас отошлют к материалам сайта kpolyakov.spb.ru. За бессвязный поток слов и неспособность формулировать свои мысли — бан.

Если у вас не сходится ответ на какую-то задачу, пожалуйста сразу представляйте свое «правильное» решение.
Программы "заворачивайте" в тэг [pre2]...[/pre2], при этом сохраняются все отступы и применяется моноширинный шрифт. Если у вас используется сочетание "[i]" для обозначения элемента массива или строки, ставьте пробел после открывающей скобки. Иначе система выделит все дальнейшее курсивом.

Для регистрации на форуме щелкните по ссылке «Вход-регистрация» вверху страницы. В открывшееся окошко «ник» введите свою фамилию на русском языке (например, Иванов). В окошко «пароль» введите придуманный вами пароль, состоящий из латинских букв и цифр. Поставьте галочку в окошке «зарегистрироваться, я новый участник» и нажмите кнопку «ОК».

АвторСообщение



Сообщение: 24
ссылка на сообщение  Отправлено: 08.12.22 13:14. Заголовок: тип 23 задача 173, у меня 43416124, в ответе 43413100


 
from functools import lru_cache
@lru_cache
def f(start, x,n):
if start > x:
return 0
if start == x:
return 1
if start == 33:
return 0
k = f(start + 1, x,1) + f(start + 3, x,2)
if n != 3:
k += f(start*2,x,3)
return k
print(f(2,18,0)*f(18,51,0))


Спасибо: 0 
ПрофильЦитата Ответить
Ответов - 4 [только новые]







Сообщение: 78
ссылка на сообщение  Отправлено: 12.12.22 09:07. Заголовок: Вы не учитываете, чт..


Вы не учитываете, что попав в 18 через команду умножить на 2, нельзя применять эту команду снова.

Как вариант, решить так. Правда, работает медленно
def f(st, fn, p, n): 
if st > fn or st == 33 or '33' in p:
return 0
if st == fn and 18 in n:
return 1
return f(st + 1, fn, p + '1', n + [st + 1]) + f(st + 3, fn, p + '2', n + [st + 3]) + f(st * 2, fn, p + '3', n + [st * 2])



print(f(2, 51, '', []))


Спасибо: 0 
ПрофильЦитата Ответить



Сообщение: 26
ссылка на сообщение  Отправлено: 13.12.22 14:03. Заголовок: спасибо!!..


спасибо!!

Спасибо: 0 
ПрофильЦитата Ответить



Сообщение: 27
ссылка на сообщение  Отправлено: 13.12.22 14:07. Заголовок: спасибо!!..


спасибо!!

Спасибо: 0 
ПрофильЦитата Ответить





Сообщение: 218
ссылка на сообщение  Отправлено: 17.12.22 02:48. Заголовок: L4043 пишет: def f(..


L4043 пишет:

 цитата:
def f(st, fn, p, n):
if st > fn or st == 33 or '33' in p:
return 0
if st == fn and 18 in n:
return 1
return f(st + 1, fn, p + '1', n + [st + 1]) + f(st + 3, fn, p + '2', n + [st + 3]) + f(st * 2, fn, p + '3', n + [st * 2])
print(f(2, 51, '', []))


Очень красивое решение, но для тех кто работал только в паскале оно непонятно от слова совсем.
Для интересующихся могу предложить более наглядное решение в Excel

Строки с надписью скрыто были созданы для уменьшения размера картинки, тем более, что там формулы аналогичные тем что сверху или снизу

Спасибо: 0 
ПрофильЦитата Ответить
Ответ:
1 2 3 4 5 6 7 8 9
видео с youtube.com картинка из интернета картинка с компьютера ссылка файл с компьютера русская клавиатура транслитератор  цитата  кавычки оффтопик свернутый текст

показывать это сообщение только модераторам
не делать ссылки активными
Имя, пароль:      зарегистрироваться    
Тему читают:
- участник сейчас на форуме
- участник вне форума
Все даты в формате GMT  3 час. Хитов сегодня: 6354
Права: смайлы да, картинки да, шрифты нет, голосования нет
аватары да, автозамена ссылок вкл, премодерация откл, правка нет