17.01 Обработка пар элементов последовательности
Ошибка.
Попробуйте повторить позже
В файле содержится последовательность натуральных чисел. Элементы последовательности могут принимать целые
значения от до
включительно. Определите количество пар последовательности, в которых хотя
бы одно число делится на минимальный элемент последовательности, кратный
. Гарантируется, что
такой элемент в последовательности есть. В ответе запишите количество найденных пар, затем, через пробел,
максимальную из сумм элементов таких пар. В данной задаче под парой подразумевается два различных элемента
последовательности.
Решение программой
Напишем программу, которая будет проверять все пары различных элементов последовательности, подсчитывая те, в которых хотя бы одно число делится на минимальный элемент последовательности, кратный 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)
Специальные программы

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

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

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

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

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

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