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

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

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

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

Задача 1#61012

В файле содержится последовательность натуральных чисел. Элементы последовательности могут принимать целые значения от 1  до 100000  включительно. Определите количество пар последовательности, в которых хотя бы одно число делится на минимальный элемент последовательности, кратный 24  . Гарантируется, что такой элемент в последовательности есть. В ответе запишите количество найденных пар, затем, через пробел, максимальную из сумм элементов таких пар. В данной задаче под парой подразумевается два различных элемента последовательности.

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

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

Напишем программу, которая будет проверять все пары различных элементов последовательности, подсчитывая те, в которых хотя бы одно число делится на минимальный элемент последовательности, кратный 24. Сначала найдём минимальный элемент, кратный 24, в последовательности. Затем переберём все пары и проверим, делится ли хотя бы один из элементов пары на найденное минимальное число. Если условие выполняется, считаем такую пару подходящей и сохраняем сумму элементов пары для определения максимальной суммы. В конце программа выведет количество подходящих пар и максимальную сумму элементов таких пар.

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

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

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

# переменная для хранения минимального элемента, кратного 24 (берём большое число для начала)
min24 = 100000000

# переменная для хранения максимальной суммы подходящих пар (берём большое отрицательное число)
maxim = -100000000

# находим минимальный элемент последовательности, кратный 24
for i in range(len(a)):
    if a[i] % 24 == 0 and a[i] < min24:
        min24 = a[i]

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

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

Ответ: 627984 175833

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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