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

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

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

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



Сообщение: 1
ссылка на сообщение  Отправлено: 10.12.21 02:46. Заголовок: Задание №17. Задача №204


Условие: В файле 17-204.txt содержится последовательность целых чисел, которые принимают значения от -10000 до 10000 включительно. Тройка идущих подряд чисел последовательности называется уникальной, если только второе из них является положительным числом, заканчивающимся на 9. Определите количество уникальных троек чисел, а затем – максимальную из всех сумм таких троек.
Мой код:
f = open("C:/Users/Home-PC/Desktop/17.txt", 'r') 
string = f.read()
mass = string.split()
kol = 0
nmax = 0
for i in range(len(mass)-2):
n1 = mass[ i ]
n2 = mass[i+1]
n3 = mass[i+2]
if int(n1) <= 0 and int(n3) <= 0 and int(n2) % 10 == 9 and int(n2) > 0:
kol += 1
if int(n1) + int(n2) + int(n3) > nmax:
nmax = int(n1) + int(n2) + int(n3)
print(kol, nmax)

Мой ответ: 63 6241 (неправильный)
Очень интересует, что у меня в коде неправильно, голову уже ломаю минут 40. Из условия сказано, что ТОЛЬКО второе число из тройки должно быть положительным и оканчиваться на 9. Отсюда следует, что первое и третье числа должны быть <= 0. Все проверил несколько раз и всё равно не пойму что не так... Помогите пожалуйста.

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







Сообщение: 544
ссылка на сообщение  Отправлено: 10.12.21 13:23. Заголовок: if (int(n1)<=0 o..


if (int(n1)<=0 or int(n1)%10!=9) and (int(n3)<=0 or int(n3)%10!=9) and int(n2) % 10 == 9 and int(n2) > 0:  
kol += 1
if int(n1) + int(n2) + int(n3) > nmax:
nmax = int(n1) + int(n2) + int(n3)


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

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