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

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

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

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





Сообщение: 395
ссылка на сообщение  Отправлено: 28.02.21 21:00. Заголовок: Вопрос по №79


Получаю 690, а в ответах 852
Мой код:
 def f(n): 
if n<=5:
return n
elif n%3==0:
return n+f(n/3+1)
else:
return 0

for i in range(1,1000):
x = f(i)
if x>1000:
print(i, f(i))


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


Администратор




Сообщение: 2522
ссылка на сообщение  Отправлено: 28.02.21 21:05. Заголовок: cabanov.alexey пишет..


cabanov.alexey пишет:
 цитата:
return 0

Это почему так?
Один из вариантов решения здесь.

___________________________________________________
Имей мужество пользоваться собственным умом. (И. Кант)
Спасибо: 0 
ПрофильЦитата Ответить





Сообщение: 396
ссылка на сообщение  Отправлено: 28.02.21 21:24. Заголовок: Ошибку осознал, спас..


Ошибку осознал, спасибо!
 def F(n):  
if n <= 5:
return n
if n % 3 == 0:
fn = F(n//3 + 1)
return n + fn if fn!=0 else 0
else:
return 0

n = 1
while True:
r = F(n)
if r != None and r > 1000:
print(n, r)
break
n += 1


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



Сообщение: 3
ссылка на сообщение  Отправлено: 16.03.21 11:02. Заголовок: Осмелюсь предложить ..


Осмелюсь предложить еще такой вариант решения
 
def f(n):
if n<=5:
return n
elif n%3==0:
return n+f(n/3+1)
else:
return n+f(n+3)

n=0
k=0

while n<1000 and k<1000:
n=n+1
nt=n
st=0
tr=0
while nt>12 and st==0:

if (nt/3+1)%3==0:
nt=int(nt/3+1)

else:
st=1

if st==0:
k=f(n)
print(k, n)


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



Сообщение: 4
ссылка на сообщение  Отправлено: 18.03.21 11:25. Заголовок: А вот такой вариант ..


А вот такой вариант предложил один из учеников. Учитывая, что вторая ветвь рекурсии нам не нужна, т.к. она не дает решения, заменяем ее на отрицательное число, для того чтобы цикл не прервался.
 
def f(n):
if n<=5:
return n
elif n%3==0:
return n+f(n/3+1)
else:
return -5000000000


x=0
while f(x)<=1000:
x=x+1
print(x, f(x))


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

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