Тема 17. Обработка числовой последовательности

17.01 Обработка пар элементов последовательности

Вспоминай формулы по каждой теме
Решай новые задачи каждый день
Вдумчиво разбирай решения
ШКОЛКОВО.
Готовиться с нами - ЛЕГКО!
Подтемы раздела обработка числовой последовательности
Решаем задачу:

Ошибка.
Попробуйте повторить позже

Задача 1#60988

В файле содержится последовательность из 10000  целых положительных чисел. Каждое число не превышает 10000  . Определите и запишите в ответе через пробел сначала количество пар элементов последовательности, у которых сумма элементов кратна 44  и хотя бы один элемент из пары делится на 11  , затем максимальную из сумм элементов таких пар. В данной задаче под парой подразумевается два различных элемента последовательности. Порядок элементов в паре не важен.

Вложения к задаче
Показать ответ и решение

Решение программой

Напишем программу, которая будет проверять все пары различных элементов последовательности. Нужно найти пары, у которых сумма элементов кратна 44. Для этого берём сумму пары и проверяем остаток от деления на 44 — если он равен нулю, сумма кратна 44. Также для пары должно выполняться условие, что хотя бы один из элементов делится на 11 — проверяем это через остаток от деления на 11. Если хотя бы один элемент делится на 11, условие выполняется.

В программе подсчитываем количество таких пар и сохраняем максимальную из сумм этих пар. В конце выводим количество и максимальную сумму.

# открываем файл с числами
f = open("17.txt")

# считываем все числа из файла в список
a = [int(i) for i in f.readlines()]

# переменные для подсчёта количества подходящих пар и хранения максимальной суммы
count = 0
maxim = 0

# перебираем все пары различных элементов (i < j)
for i in range(len(a) - 1):
    for j in range(i + 1, len(a)):
        # проверяем, что сумма кратна 44
        # и хотя бы один элемент делится на 11
        if (a[i] + a[j]) % 44 == 0 and (a[i] % 11 == 0 or a[j] % 11 == 0):
            count += 1
            maxim = max(maxim, a[i] + a[j])

# выводим количество подходящих пар и максимальную сумму
print(count, maxim)

Ответ: 109314 19976

Специальные программы

Все специальные программы

Программа
лояльности v2.0

Приглашай друзей в Школково и получай вознаграждение до 10%!

Крути рулетку
и выигрывай призы!

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

Бесплатное онлайн-обучение

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

Налоговые вычеты

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

Специальное предложение
для учителей

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

Вернём деньги за курс
за твою сотку на ЕГЭ

Сдать экзамен на сотку и получить обратно деньги за подготовку теперь вполне реально!

cyberpunkMouse
cyberpunkMouse
Рулетка
Вы можете получить скидку в рулетке!