Задача к ЕГЭ по информатике на тему «пары/тройки чисел, выбрать из каждой, кратность» №6

Имеется набор данных, состоящий из троек положительных целых чисел. Необходимо выбрать из каждой тройки два числа так, чтобы сумма всех выбранных чисел не делилась на 15 и при этом была максимально возможной. Гарантируется, что искомую сумму получить можно. Программа должна напечатать одно число – максимально возможную сумму, соответствующую условиям задачи.

Входные данные: Даны два входных файла: файл A  (27_7A.txt) и файл B  (27_7B.txt), каждый из которых содержит в первой строке количество троек N  (1 ≤ N ≤ 100000)  . Каждая из следующих N  строк содержит три натуральных числа, не превышающих 1000.

В ответе укажите два числа через пробел: сначала значение искомой суммы для файла A  , затем для файла B  .

f = open(’27_7B.txt’)
n = int(f.readline())
s = 0
#минимальная разность
mr = 1000050000000
for i in range(n):
    #тройка чисел из файла в порядке возрастания
    a = sorted(map(int, f.readline().split()))
    #сумма двух наибольших чисел из тройки
    s += a[1] + a[2]
    #проверяем разницу между наименьшим и средним числом в тройке,
    #и обновляем минимальную разницу, исключая деление на 15
    if (a[1] - a[0] < mr) and ((a[1] - a[0]) % 15 != 0):
        mr = a[1] - a[0]
    #проверяем разницу между наименьшим и средним числом в тройке,
    #и обновляем минимальную разницу, исключая деление на 15
    if (a[2] - a[0] < mr) and ((a[2] - a[0]) % 15 != 0):
        mr = a[2] - a[0]
#проверяем, делится ли сумма на 15
if s % 15 != 0:
    #если нет, выводим сумму
    print(s)
else:
    #если да, вычитаем минимальную разницу из суммы и выводим
    s -= mr
    print(s)

Ответ: 58284 125061935
Оцените статью
Я решу все!