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

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

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

Пример входных данных:

5

3 8

35 29

13 31

4 4

44 44

Для таких входных данных значением искомое суммы будет число 122

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

f = open("27.txt")
n = int(f.readline())
ans = 0  # Переменная для максимальной суммы
diff = 10 ** 10  # Минимальная разность, некратная 4
for i in range(n):
    a = [int(i) for i in f.readline().split()]
    ans += max(a)  # Прибавляем максимальное число к сумме
    if abs(a[0] - a[1]) % 4 != 0:  # Если разность чисел некратна 4
        diff = min(diff, abs(a[0] - a[1]))  # Пробуем сохранить разность

if ans % 4 == 0:  # Если сумма в итоге делится на 4
    if diff != 10 ** 10:
        ans -= diff  # Вычитаем некратную разность, чтобы сумма в итоге стала некратной
    else:
        ans = 0  # Иначе присваиваем 0 для вывода
print(ans)

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