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

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

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

5

15  8

5  11

6  3

7  2

9  14

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

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

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

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

f = open(’17.txt’)
n = int(f.readline())
sMin = 0
count = [0, 0]
md01 = 10000000000000000  # миндифф для пары чет/нечет
pmd01 = 10000000000000000  # предминдифф для пары чет/нечет
md10 = 10000000000000000  # миндифф для пары нечет/чет
pmd10 = 10000000000000000  # предминдифф для пары нечет/чет
for i in range(n):
    x, y = map(int, f.readline().split())
    sMin += min(x, y)
    count[min(x, y) % 2] += 1
    diff = max(x, y) - min(x, y)
    if diff % 2 == 1:
        if min(x, y) % 2 == 0:
            if diff < md01:
                pmd01 = md01
                md01 = diff
            elif diff < pmd01:
                pmd01 = diff
        else:
            if diff < md10:
                pmd10 = md10
                md10 = diff
            elif diff < pmd10:
                pmd10 = diff
if count[sMin % 2] == max(count):
    print(sMin)
elif max(count) - min(count) == 1:
    if max(count) == count[0]:
        print(sMin + min(md10, md01 + pmd01))
    else:
        print(sMin + min(md01, md10 + pmd10))
else:
    if max(count) == count[0]:
        print(sMin + min(md10, md01))
    else:
        print(sMin + min(md10, md01))

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