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

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

Пример входного файла:

5

15  8

5  11

6  3

7  2

9  14

Ответ для данного примера: 53

Идея: соберем сумму из всех максимумов, если ее четность совпадает с четностью большинства, то все хорошо. Если нет, то может быть два случая — чисел какой-то четности намного больше, чем другой (>=3), либо количества отличаются на 1.

В первом случае достаточно сделать просто минимальную нечетную замену (в какой-то паре взять не максимальное число, а минимальное так, чтобы разность между числами в паре была минимальной нечетной из всех пар).

Во втором случае может так случиться, что при такой замене (для примера у нас сейчас четных на 1 больше, чем нечетных, а сумма нечетна) мы заменим одно четное четное на нечетное, теперь сумма стала четной, но нечетных стало больше. У нас есть два варианта — либо произведем одну замену нечет/чет, тогда четность суммы изменится, а баланс сохранится, либо произведем две замены чет/нечет, тогда баланс изменится, а четность суммы сохранится.

f = open(’15.txt’)
n = int(f.readline())

sMax = 0  # Максимальная сумма, которую можно собрать
count = [0, 0]  # Счетчик четных и нечетных чисел
md01 = 10000000000000000  # миндифф для пары чет/нечет
pmd01 = 10000000000000000  # предминдифф для пары чет/нечет
md10 = 10000000000000000  # миндифф для пары нечет/чет
pmd10 = 10000000000000000  # предминдифф для пары нечет/чет

for i in range(n):
    x, y = map(int, f.readline().split())
    sMax += max(x, y)
    count[max(x, y) % 2] += 1
    diff = max(x, y) - min(x, y)
    if diff % 2 == 1:
        # Соберем мин разности для конкретных замен нечет/чет и чет/нечет
        if max(x, y) % 2 == 1:
            if diff < md10:
                pmd10 = md10
                md10 = diff
            elif diff < pmd10:
                pmd10 = diff
        else:
            if diff < md01:
                pmd01 = md01
                md01 = diff
            elif diff < pmd01:
                pmd01 = diff

if count[sMax % 2] == max(count):
    print(sMax)
elif max(count) - min(count) == 1:
    if max(count) == count[0]:
        print(sMax - min(md10, md01 + pmd01))
    else:
        print(sMax - min(md01, md10 + pmd10))
else:












































































































































































































    if max(count) == count[0]:
        print(sMax - min(md10, md01))
    else:
        print(sMax - min(md10, md01))

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