17.01 Обработка пар элементов последовательности
Ошибка.
Попробуйте повторить позже
В файле содержится последовательность целых чисел. Элементы последовательности могут принимать целые значения от 0 до 100000 включительно. Определите и запишите в ответе через пробел сначала количество пар чисел, в которых хотя-бы один из двух элементов больше, чем остаток от деления суммы всех чисел в файле на 12345, а шестнадцатеричная запись другого оканчивается на F, а затем — минимальную сумму элементов таких пар. Если оба числа больше, чем остаток от деления суммы всех чисел в файле на 12345, то хотя бы одно из них в шестнадцатеричной записи должно кончаться на F. В данной задаче под парой подразумевается два идущих подряд элемента последовательности.
Например для последовательности из шести элементов:
17444; 31; 54278; 9099; 17022; 37563; Ответ: 2 17475
Для выполнения этого задания можно написать программу или воспользоваться редактором электронных таблиц.
Решение программой
Сначала считаем все числа из файла и найдём остаток от деления их суммы на 12345 — он нужен для сравнения в дальнейшем. Далее переберём все пары соседних чисел. Условие, по которому отбираем подходящие пары, следующее: хотя бы одно из чисел в паре должно быть больше этого остатка, а шестнадцатеричная запись другого должна заканчиваться на F (то есть число даёт остаток 15 при делении на 16). Также учитываем случай, если оба числа больше остатка — тогда хотя бы одно из них должно оканчиваться на F. Для каждой подходящей пары будем подсчитывать их количество и сохранять минимальную сумму.
f = open(’17.txt’) a = [int(x) for x in f] # Остаток от деления суммы всех чисел в файле на 12345 ostat = sum(a) % 12345 # Количество найденных пар count = 0 # Минимальная сумма элементов пар mins = 100000000 # Проходимся по всем парам чисел for i in range(len(a) - 1): # Если пара нам подходит - обновляем ответ if (a[i] > ostat and a[i+1] % 16 == 15) or \ (a[i+1] > ostat and a[i] % 16 == 15) or \ (a[i] > ostat and a[i+1] > ostat and \ (a[i] % 16 == 15 or a[i+1] % 16 == 15)): count += 1 mins = min(mins, a[i]+a[i+1]) # Выводим ответ print(count, mins)
Специальные программы

Программа
лояльности v2.0
Приглашай друзей в Школково и получай вознаграждение до 10%!

Крути рулетку
и выигрывай призы!
Крути рулетку и покупай курсы со скидкой, которая привязывается к вашему аккаунту.

Бесплатное онлайн-обучение
Для школьников из приграничных территорий России, проживающих в ДНР, ЛНР, Херсонской, Запорожской, Белгородской, Курской, Брянской областях и Крыму.

Налоговые вычеты
Узнай, как получить налоговый вычет при оплате обучения в «Школково».

Специальное предложение
для учителей
Бесплатный доступ к любому курсу подготовки к ЕГЭ, ОГЭ и олимпиадам от «Школково». Мы с вами делаем общее и важное дело, а потому для нас очень значимо быть чем-то полезными для учителей по всей России!

Вернём деньги за курс
за твою сотку на ЕГЭ
Сдать экзамен на сотку и получить обратно деньги за подготовку теперь вполне реально!